Mongoid 文件上传CarrierWave 和paperclip

RAILS中使用mongoDB二种选择,mongoid和mongoMapper,不过MM我个人感觉对RAILS3支持不好,而且现在不能很好的和 devise 结合,所以最终选择mongoid。
mongoid上传有二种选择,一种是CarrierWave,比较好地支持mongoid,
CarrierWave
1.安装CarrierWave gem,
sudo gem install carrierwave 

2.配置Gemfile
gem "carrierwave"

3.生成uploader
rails generate uploader Avatar
这里要注意,正常应该生成
app/uploader/avatar_uploader.rb
不过现在好像有问题,生成的文件名:avatar.rb,要自己改成avatar_uploader.rb
4.创建示例
 rails g scaffold user name:string
生成用户
5.为用户添加头像
    require 'carrierwave/orm/mongoid'
class Post
include Mongoid::Document
field :name

mount_uploader :file, AvatarUploader
end

6,修改表单
        <%= form_for(@user, :html => {:multipart => true}) do |f| %>

<div class="field">
<%= f.label :name %><br />
<%= f.text_field :name %>
</div>
<div class="field">
<%= f.label :FIle %><br />
<%= f.file_field :avatar %>
</div>
<div class="actions">
<%= f.submit %>
</div>
<% end %>

7.修改show.html.erb
添加
<%=image_tag @user.avatar_url%>

具体设置什么可以参考:[url]http://github.com/jnicklas/carrierwave[/url]

不过我个人感觉 carrierwave并不完善,已发现问题:
1.更新不会删除原来的文件
2,删除记录不会删除文件夹,同时,如果如果更新过,产生的以前的文件也不会删除,这个比较让人头痛
3.白名单验证在mongoid 下有问题,不起作用。。例如我用
 def extension_white_list
%w(jpg jpeg gif png)
end

结果无效,ActiveRecord下正常。

paperclip比较强大,但在mongoid 下有问题,修改点东西就可以了
1. 在config/initializers/paperclip中加上
Paperclip.options[:log] = false


2.修改model
    class Post
include Mongoid::Document
include Paperclip
field :title
field :body
field :file_file_name
field :file_content_type
field :file_file_size, :type => Integer
field :file_updated_at, :type => Time

has_attached_file :file
end

经过修改目前可以正常工作,

总结,CarrierWave比较好地支持mongoid,不过存在这样那样的问题,改起来比较麻烦,paperclip没有全面支持mongoid,不过修改一点东西就可以很好地使用,于是,又换回paperclip了。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<div v-else-if="per.dict_value === 'file_name'"> <el-tooltip placement="top" effect="dark" v-if="scope.row.download_time || scope.row.repair_download_time"> <div slot="content" > <span v-if="scope.row.repair_download_time">{{ parseTime(scope.row.repair_download_time,'{y}-{m}-{d} {h}:{i}:{s}') }}</span> <span v-else-if="scope.row.download_time">{{ parseTime(scope.row.download_time,'{y}-{m}-{d} {h}:{i}:{s}') }}</span> </div> <el-link v-if="scope.row.repair_file_id" :key="scope.row.repair_file_id" style="display: block;color: #67C23A" icon="el-icon-paperclip" @click="downloadOrderExcel(scope.row.repair_file_id, scope.row.order_no, scope.row.repair_file_name)" >{{ scope.row.repair_file_name }}</el-link> <el-link v-else-if="scope.row.file_id" :key="scope.row.file_id" style="display: block;color: #67C23A" icon="el-icon-paperclip" @click="downloadOrderExcel(scope.row.file_id, scope.row.order_no, scope.row.file_name)" >{{ scope.row[per.dict_value] }}</el-link> </el-tooltip> <div v-else> <el-link v-if="scope.row.repair_file_id" :key="scope.row.repair_file_id" style="display: block;" icon="el-icon-paperclip" @click="downloadOrderExcel(scope.row.repair_file_id, scope.row.order_no, scope.row.repair_file_name)" >{{ scope.row.repair_file_name }}</el-link> <el-link v-else-if="scope.row.file_id" :key="scope.row.file_id" style="display: block;" icon="el-icon-paperclip" @click="downloadOrderExcel(scope.row.file_id, scope.row.order_no, scope.row.file_name)" >{{ scope.row[per.dict_value] }}</el-link> </div> </div>优化这段代码用vue2.0
06-07

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值