Railsプラグインacts_as_flying_saucerを使用してPDFを生成していますが、PDFが機能しません。保存しても問題ありませんが、開こうとすると次のエラーメッセージが表示されます。
Unable to open document
File type SOR File (text/plain) is not supported
これが私の設定です。Rails2.3.4と最新バージョンのacts_as_flying_saucerプラグインを使用しています。私はこのルートを持っています:
map.all_help '/help/all.:format', :controller => "help", :action => "all"
これは、このコントローラーのアクションになります。
class HelpController < ApplicationController
acts_as_flying_saucer
def all
respond_to do |format|
format.html {
render :action => "all", :layout => "help_pdf"
}
format.js
format.pdf {
render_pdf :template => 'help/all.html.erb',
:layout => "help_pdf",
:send_file => { :filename => "my-filename.pdf", :type => "application/pdf"}
}
end
end
end
そして私はこのmimeタイプも定義しています:
Mime::Type.register "application/pdf", :pdf
/help/all.pdfページに移動すると、0バイトのpdfが生成され(保存できます)、この投稿を開こうとすると、この投稿の上部からエラーメッセージが表示されます。
ページの標準のWebページバージョン(/ help / all)に移動すると、正常に機能します。Java VMが設定されていないのではないかと思いましたが、問題ないようです。
max-laptop:millionaire[subjects]$ java -version
java version "1.6.0_20"
Java(TM) SE Runtime Environment (build 1.6.0_20-b02)
Java HotSpot(TM) Client VM (build 16.3-b01, mixed mode, sharing)
私はこの時点でアイデアがありません...アドバイスに感謝します!最大
編集:たくさんのエラー出力が私の雑種犬の実行タブにあることに気づきました:
ERROR: 'Premature end of file.'
Exception in thread "main" org.xhtmlrenderer.util.XRRuntimeException: Can't load the XML resource (using TRaX transformer). org.xml.sax.SAXParseException: Premature end of file.
at org.xhtmlrenderer.resource.XMLResource$XMLResourceBuilder.createXMLResource(XMLResource.java:191)
at org.xhtmlrenderer.resource.XMLResource.load(XMLResource.java:71)
at org.xhtmlrenderer.swing.NaiveUserAgent.getXMLResource(NaiveUserAgent.java:205)
at org.xhtmlrenderer.pdf.ITextRenderer.loadDocument(ITextRenderer.java:102)
at org.xhtmlrenderer.pdf.ITextRenderer.setDocument(ITextRenderer.java:106)
at Xhtml2Pdf.main(Xhtml2Pdf.java:19)
Caused by: javax.xml.transform.TransformerException: org.xml.sax.SAXParseException: Premature end of file.
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:719)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:313)
at org.xhtmlrenderer.resource.XMLResource$XMLResourceBuilder.createXMLResource(XMLResource.java:189)
... 5 more
Caused by: org.xml.sax.SAXParseException: Premature end of file.
at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1231)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transformIdentity(TransformerImpl.java:636)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:707)
... 7 more
PDFに変換しようとしているページに何か問題があるのではないかと思います。w3cバリデーターを過ぎてページのhtmlバージョンを実行したところ、ページは正常に検証されました。だから今、私は再び困惑しています...
編集2:私は今近づいていると思います:私のログを見ると、私は見る
Rendering help/all.html.erb
html file: /tmp/ff4c8ff01d544500ea4bfea43e6108c1.html
Sending X-Sendfile header /tmp/ff4c8ff01d544500ea4bfea43e6108c1.pdf
したがって、/tmp/ff4c8ff01d544500ea4bfea43e6108c1.htmlに私のページのhtmlバージョンが含まれていると思いますが、これは4行の空のテキストファイルです。フライングソーサーがそれを変換できないのも不思議ではありません。空のhtmlファイルを保存している理由はわかりません。
編集3:これが私が現在変換しようとしているhtmlです
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>Help for Millionaire For Schools</title>
</head>
<body class="pdf">
<div id="bgeffect"></div>
<div id="pageWrapper" class="mainHelpPages">
<div id="helpContent">
<div id="helpPane">
<div class="inner">
<p>Welcome to my pdf</p>
</div>
</div>
</div>
</div>
</body>
</html>