Rails处理图片上传: CarrierWave
文件上传可以说处处都有,我们在论坛中上传附件,在注册一个新用户时上传头像, 编辑一个文章时要上传图片等等。
CarrierWave(https://github.com/carrierwaveuploader/carrierwave) 用来把客户端上传的图片保存到服务器本地。它支持包括Rails, Sinatra 在内的多种框架。
注意: 以下仅支持 carrierwave 0.9.0 版本. 0.10.0 与 1.0 版本的用法略有变化, 请注意查看官方文档
1.0 版本仅支持 ruby 2.0 与 rails 4 .
使用
in Gemfile:
gem 'carrierwave', '0.9.0'
$ rails generate uploader Logo
会新建一个这样的model:
# this will create file: app/uploaders/logo_uploader.rb
class AvatarUploader < Logo::Uploader::Base
storage :file
end
`
同时, 务必记得 为对应的model 增加 列: Avatar
# -*- encoding : utf-8 -*-
class AddSnapshotToMarketModules < ActiveRecord::Migration
def change
add_column :market_modules, :avatar, :string, default: '', comment: '保存截图路径'
end
end
in your model:
class Item < ActiveRecord::Base
mount_uploader :logo, LogoUploader
end
in your view:
<%= f.file_field :logo %>
in controller :
# do nothing....
item.create(params[:item])
# or
item.logo = params[:file]
item.save
对于 rails4, 只需要把 avatar 这个属性加入到 参数白名单列表中:
def item_params
params.require(:item).permit(:market_id, :name, :level, :avatar)
end
用法:
<%= image_tag @item.logo.url, :style => 'height: 200px' %>