nginx - 利用 Carrierwave 上傳的圖片在 production 環境中不顯示
問題描述
我項目中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 endend
在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是存在于該路徑下的。
所以,這是哪里出了錯?該怎么辦?
問題解答
回答1:可以通過 photo.url(:thumb) 試試
相關文章:
1. mysql - linux連接數據庫報錯2. python - flask報錯ValueError: invalid key ’nicknickname’3. css - 如何選擇字體?4. javascript - h5微信中怎么禁止橫屏5. MYSQL 根據兩個字段值查詢 但兩個值的位置可能是互換的,這個怎么查?6. php - MySQL數據庫設計,獲取點贊的人數7. javascript - 有適合開發手機端Html5網頁小游戲的前端框架嗎?8. mysql - 這種分級一對多,且分級不平衡的模型該怎么設計表?9. MySQL中的enum類型有什么優點?10. java - 線上應用,如果數據庫操作失敗的話應該如何處理?
