nginx - 利用 Carrierwave 上傳的圖片在 production 環境中不顯示
高洛峰
高洛峰 2017-04-22 08:59:03
0
1
632

我項目中Uploader的代碼如下:

class PhotoUploader < CarrierWave::Uploader::Base

  include CarrierWave::MiniMagick
  process :resize_to_fit => [nil, 600]

  version :thumb do
    process :resize_to_fill => [150,150]
  end

  # Choose what kind of storage to use for this uploader:
  storage :file

  def store_dir
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
  end

  def cache_dir
    "#{Rails.root}/tmp/uploads"
  end

  def extension_white_list
    %w(jpg jpeg gif png)
  end

  def filename
    if original_filename
      @name ||= Digest::MD5.hexdigest(current_path)
      "#{@name}.#{file.extension}"
    end
  end

end

production.rb中,設置config.serve_static_assets = false

利用Capistrano部署到Nginx Passenger的生產環境中後,每次上傳圖片後會根據uploader的設置生成兩份,就像這樣:

其中,訪問第一個圖片可以正常顯示,訪問第二個(version :thumb)處理過的圖片無法顯示,報出:

ActionController::RoutingError (No route matches [GET] "/uploads/picture/photo/49/thumb_6d9596c7449d3714eadb74b9c71beec2.jpg")

這樣的錯誤,而實際上這裏麵的thumb_6d9596c7449d3714eadb74b9c71beec2.jpg是存在於該路徑下的。

所以,這是哪裏出了錯?該怎麼辦?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回覆(1)
黄舟

可以透過 photo.url(:thumb) 試試

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板