Wicked_PDF を使用して PDF をレンダリングする際に問題があります。Amazon S3 と CloudFront を使用してすべてのアセット パイプライン リソースをホストしていますが、開発中に問題なく生成されます。ただし、本番環境では、生成された PDF で HTML および CSS アセットがレンダリングされません。
Rails 3.2.11、Ruby 1.9.3p327、MAC OSX 10.8.2、wkhtmltopdf 0.9.9、および現在のバージョンの Wicked_PDF と wkhtmltopdf-heroku を実行しています。
関連するすべての情報は次のとおりです。
Heroku ログ:
2013-04-21T14:13:19.482011+00:00 app[web.1]: Completed 302 Found in 212ms (ActiveRecord: 205.6ms)
2013-04-21T14:13:19.584108+00:00 app[web.1]: Started GET "/office/download/7" for ip_address at 2013-04-21 14:13:19 +0000
2013-04-21T14:13:21.551581+00:00 app[web.1]: Processing by OfficesController#show_pdf as HTML
2013-04-21T14:13:21.551581+00:00 app[web.1]: ***************WICKED***************
2013-04-21T14:13:21.551581+00:00 app[web.1]: Parameters: {"office_id"=>"7"}
2013-04-21T14:13:21.551581+00:00 app[web.1]: Rendered appointments/forms/_office.pdf.html.erb within layouts/pdf.html (13.6ms)
2013-04-21T14:13:21.551581+00:00 app[web.1]: Rendered text template (0.0ms)
2013-04-21T14:13:21.551581+00:00 app[web.1]: Sent data Office.pdf (42.2ms)
2013-04-21T14:13:21.551581+00:00 app[web.1]: Completed 200 OK in 1961ms (Views: 41.9ms | ActiveRecord: 7.8ms)
2013-04-21T14:13:21.554211+00:00 heroku[router]: at=info method=GET path=/office/download/7
host=www.foobar.com fwd="ip_address" dyno=web.1 connect=1ms service=1971ms status=200 bytes=22019
ルート:
# => Route that generates the PDF
get "/office/download/:office_id" => 'offices#show_pdf'
コントローラ:
# => app/controllers/offices_controller.rb
def show_pdf
@office = Office.find_by_id(params[:office_id])
abrv = @office.abrv
partial = "appointments/forms/_#{abrv}"
@format = "pdf"
respond_to do |format|
format.pdf do
render :pdf => "#{@office.name}",
:template => "#{partial}.pdf.html.erb",
:layout => "pdf.html",
:page_size => "A4",
:encoding => "UTF-8",
:show_as_html => params[:debug].present?
end
end
end
意見:
# => app/views/offices/index
<div>
# List of all offices
</div>
# PDF partials for each office
<%= render 'appointments/forms/office.pdf.html.erb' %>
<%= render 'appointments/forms/office_1.pdf.html.erb' %>
...
PDF テンプレート:
# => app/views/appointments/forms/_office.pdf.html.erb:
<% if @format != 'pdf' %>
<%= stylesheet_link_tag 'office' # => .css.scss.erb %>
<% else %>
<%= wicked_pdf_stylesheet_link_tag 'office' # => .css.scss.erb %>
<% end %>
<div class="pdf_styling">
<p>Bar</p>
</div>
CSS:
# => app/assets/stylesheets/office.css.scss.erb
.pdf_styling {
background-image: url('https://s3.amazonaws.com/foo/assets/pdf_background_image.jpg');
width: 100%;
height: 100%;
p {
position: absolute;
left: 100px;
right: 100px;
}
}
Wicked_PDF 初期化子:
# => config/initializers/wicked_pdf.rb
WICKED_PDF = {
:wkhtmltopdf => (Rails.env.test? || Rails.env.development? ? '/usr/local/bin/wkhtmltopdf' : Rails.root.join('bin', 'wkhtmltopdf-amd64').to_s),
:exe_path => (Rails.env.test? || Rails.env.development? ? '/usr/local/bin/ ' : Rails.root.join('vendor','bin', 'wkhtmltopdf-amd64').to_s)
}
Gemfile:
# PDF Gem
gem 'wicked_pdf'
# PDF to HTML utility
gem 'wkhtmltopdf-binary'
# PDF on heroku
group :production do
gem "wkhtmltopdf-heroku", :git => 'git://github.com/camdez/wkhtmltopdf-heroku.git'
gem 'thin'
end
# Asset Pipeline Optimization
gem "asset_sync"
繰り返しますが、開発中はすべて正常に動作しますが、本番環境では空白の PDF ページが表示されます。ログ内から発生するエラーはありません。これは、dyno が少なすぎることによる潜在的な問題ですか?
確かに、私はこれらすべてに反対です。私を許して。ありがとう。