nginx - 利用 Carrierwave 上傳的圖片在 production 環(huán)境中不顯示
問(wèn)題描述
我項(xiàng)目中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中,設(shè)置config.serve_static_assets = false。
利用Capistrano部署到Nginx + Passenger的生產(chǎn)環(huán)境中后,每次上傳圖片后會(huì)根據(jù)uploader的設(shè)置生成兩份,就像這樣:
其中,訪問(wèn)第一個(gè)圖片可以正常顯示,訪問(wèn)第二個(gè)(version :thumb)處理過(guò)的圖片無(wú)法顯示,報(bào)出:
ActionController::RoutingError (No route matches [GET] '/uploads/picture/photo/49/thumb_6d9596c7449d3714eadb74b9c71beec2.jpg')
這樣的錯(cuò)誤,而實(shí)際上這里面的thumb_6d9596c7449d3714eadb74b9c71beec2.jpg是存在于該路徑下的。
所以,這是哪里出了錯(cuò)?該怎么辦?
問(wèn)題解答
回答1:可以通過(guò) photo.url(:thumb) 試試
相關(guān)文章:
1. 如何解決docker宿主機(jī)無(wú)法訪問(wèn)容器中的服務(wù)?2. 前端 - CSS3 box-shadow如何設(shè)置,或者用什么方法可以產(chǎn)生圖中這樣陰影的效果。3. node.js - vue-cll+sass 樣式不出來(lái) 已經(jīng)npm install sass、 sass-loader了4. html - css 如何讓文字標(biāo)題顯示在邊框上?5. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????6. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項(xiàng)7. html按鍵開(kāi)關(guān)如何提交我想需要的值到數(shù)據(jù)庫(kù)8. vim中編輯HTML文件時(shí)換行不能縮進(jìn)9. HTML5中怎么判斷用戶是否正在瀏覽頁(yè)面?10. html - 微信端video標(biāo)簽播放mp4視頻,安卓端提示視頻解析錯(cuò)誤
