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 - h5 video層級太高導致浮在div上面,如何解決?2. java - 多客戶端如何操作MQ比較合適3. html5 - video ios不能播放怎么辦?4. javascript - 圖片無法正常加載5. python中怎么對列表以區間進行統計?6. mysql - 記得以前在哪里看過一個估算時間的網站7. javascript - 如何獲取未來元素的父元素在頁面中所有相同元素中是第幾個?8. 如何合并兩張具有相同結構的mysql表9. javascript - Ajax加載Json時,移動端頁面向左上角縮小一截兒,加載完成后才正常顯示,這該如何解決?10. mysql ER_BAD_DB_ERROR: Unknown database ’test’
