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. boot2docker无法启动2. webpack - vue-cli写的项目(本地跑没有问题),准备放到Nginx服务器上,有什么配置需要改的?还有怎么部署?3. 微信公众号发送模板消息返回错误410004. 这是什么情况???5. Android明明可以直接分享,为什么还要用微信开放平台、微博开放平台的sdk?6. css3写不规则样式背景7. java - 单元测试对dao层的测试有什么好的实践方案?8. javascript - 一个字符串转换成数字,例子就是a="2,322.222",b=’1,211.21’,如何在angualr中执行相减9. css3 - 父级元素为fixed定位下,子元素绝对定位问题10. angular.js - ui-router多视图嵌套,如果保障各个ui-view下的css相互独立
