Rails 3:图像流错误:"图像...因为包含错误而无法显示"

Mis*_*hko 4 ruby-on-rails image dreamhost ruby-on-rails-3

日志说:

Started GET "/assets/2/thumb" for 110.174.88.80 at Fri Jul 01 20:11:35 -0700 2011
  Processing by AssetsController#show as HTML
  Parameters: {"id"=>"2", "style"=>"thumb"}
[/home/misha_moroshko/myfamily.moroshko.com/public/images/thumb.jpg] found!
Sent file /home/misha_moroshko/myfamily.moroshko.com/public/images/thumb.jpg (0.2ms)
Completed 200 OK in 2ms
Run Code Online (Sandbox Code Playgroud)

如果直接转到图像,则会正确获取图像.

请注意,这是我真正问题的简化示例.在实际情况下,图像不在public文件夹中,但错误是相同的.

什么可能导致这样的错误?


rails -v
=> Rails 3.0.1
ruby -v
=> ruby 1.8.7 (2008-08-11 patchlevel 72) [x86_64-linux]
Run Code Online (Sandbox Code Playgroud)

相关代码:

# config/routes.rb
match "assets/:id/:style" => "assets#show"

class AssetsController < ApplicationController
  def show
    path = Rails.root.join("public", "images", "thumb.jpg").to_s
    if File.exist?(path)
      logger.fatal "[#{path}] found!"
      send_file(path, { :type => "image/jpeg", :disposition => "inline" })
    else
      logger.fatal "[#{path}] not found!"
    end
  end
end
Run Code Online (Sandbox Code Playgroud)

Mis*_*hko 5

更换

config.action_dispatch.x_sendfile_header = "X-Sendfile"
Run Code Online (Sandbox Code Playgroud)

config.action_dispatch.x_sendfile_header = "X-Accel-Redirect"
Run Code Online (Sandbox Code Playgroud)

config/environments/production.rb解决了问题!