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. javascript - 有適合開發手機端Html5網頁小游戲的前端框架嗎?2. javascript - 關于apply()與call()的問題3. python 利用subprocess庫調用mplayer時發生錯誤4. python - Pycharm的Debug用不了5. python - pandas按照列A和列B分組,將列C求平均數,怎樣才能生成一個列A,B,C的dataframe6. html - eclipse 標簽錯誤7. 安全性測試 - nodejs中如何防mySQL注入8. javascript - axios請求回來的數據組件無法進行綁定渲染9. python - pycharm 自動刪除行尾空格10. python文檔怎么查看?
