• 嵌入的数据,倒不是经常需要修改。只是在统计、或者一些状态判断的时候很麻烦。 另外,我还遇到了一个窝心的事情,原来用早期的 carrierwave 版本学的爬虫程序,没 mount 的字段,比如是 picture 吧,那么数据库里面存的字段就是 picture_filename。现在用新版本的 rails 和 carrierwave 写了一个 graphql 服务器,默认的字段名变成了 picture,每次都需要把字段名换一下。 对于普通的 collection,直接做 JavaScript:

    db.collection.update({},{$rename:{"picture_filename":"picture"}});
    

    或者用 mongoid 在 Rails 环境下

    Picture.all.rename(picture_filename: 'picture')
    

    就可以了,在嵌入式文档里面,实在是没搞明白怎么折腾。

  • mongodb,一直在用。中间也偶尔会用到 pg。mysql 在被 oracle 收购之后,就用得很少了。 用了一段时间的 mongodb 之后,再要回去用 pg,是非常辛苦的。各种表的结构都是固定的,不像是 mongodb,随时随地的调整,加减内容,每个文档都不需要保持相同。 在数据量没有那么大的情况下,各种数据库的效率其实是差不多的。 在复杂的统计分析方面,mongodb 肯定是没有 SQL 方便,在数据量不大的时候做 aggregation 其实 SQL 有的功能基本也都能实现。数据量大的时候,通过 MapReduce 也还是可以实现的。 NoSQL 数据库,复杂的统计分析,肯定是比较麻烦实现的。这东西本来也不是为了那种上万实体,每个实体几十上百个字段的复杂系统设计的。 不过,用来搞网站还是基本够用的。

  • 我现在是直接用 string 类型了,回头用你的方法试试。

  • 询问一下,应该如何查询 DateTIme 格式的字段? 我在网上查了一下,有人说是要用 Types::DateTimeType,我得到了:uninitialized constant Types::DateTimeType 请问应该如何处理?

  • 试验了几次,感觉还是字段的问题,重新赋值了字段,将原来 picture_filename 里面的信息,复制到 picture 里面,但是需要重启之后,才能够 run。估计是内存里面还有一些残留。 诡异。

  • 两边都是 mount_uploader,我查了一下,里面存的也是一个文件名,没有任何变化。 但是,我重新存进去的可以用,原来数据导过来的就不工作,不知道还有些什么奇怪的信息,放在外面。

  • 版本差异太大了,4 年了,ruby 和 rails 的版本都升级了,原来的版本不一定能跑了。

  • 感觉是版本的问题,原来的版本 carrierwave 将信息存在 picture_filename 里面,现在好像默认是存在 picture 字段里面。 我做了复制,但是好像还是不对,依然读不出 url 来,是不是存进去的格式也发生了变化? 感觉原来存储的仅仅是一个文件名,而现在好像存储的是一个非常复杂的 json,直接吧原来的字符串赋值过去,搞不定啊。

  • 原来如此,还是比较有趣的。这种小点拨,还是非常有帮助的。

  • 非常感谢。准备尝试一下。 遇到个奇怪的问题,我的字段或函数中如果有下划线,就报错。 比如 image_url 字段,定义了,就无法使用。改成 imageurl,就对了。这是为什么啊?

  • 应该算是一个小 bug 吧。 考虑到效率问题,换成 vips 还是划算的。

  • 因为要使用 mongoid,所以不得不继续和 carrierwave 折腾。 我也想用 active_storage 啊。

  • 业余程序有能够对你有帮助,很欣慰。

  • 我没做这个测试,vips,通过 write_to_file 来保存文件,格式是跟着后缀变化的,具体格式方面,我也没有测试过。

    我看了一下代码: https://github.com/eltiare/carrierwave-vips/blob/master/lib/carrierwave/vips.rb

    def convert(extension)
      process :convert => extension
    end
    

    应该是实现了。

    我在我的代码中添加了

    process convert: 'png'
    

    执行了,没有问题。 但是,在 version 里面是错误的,程序在取 image.avatar.url 的时候会自动按照 version 相关的 url 去取 png,但其实图片是存成 jpg 了(原图是 jpg)。 然后改成了:

    version :thumb do
        process :scale => [150]
        process convert: 'png'
      end
    
      version :avatar do
        process :scale => [50]
        process convert: 'png'
      end
    

    就没有问题了。

  • 我已经搞明白了。 iterm 是不认翻墙的。 需要单独设置,比如重新设置 http_proxy 设置对了,就没有问题了。

  • 升级了最新的版本,问题解决了。 现在的问题是版本问题,如何将图片按分辨率,分版本上传上去,然后直接下载。 我上传了一张 20M 的照片,然后就悲剧了。

  • 当我添加了: config.active_storage.analyzers = [ ActiveStorage::Analyzer::QiniuImageAnalyzer, ActiveStorage::Analyzer::QiniuVideoAnalyzer ] 之后,显示 analyzers 失败。

    我很喜欢用 CarrierWave 里面的 remote_url,直接抓取外面的资源,现在怎么搞? 另外,原来 carrierwave 里面,是在上传的时候,做图像处理的,还可以添加水印、圆角什么的,现在怎么搞?是不是都要到显示的时候来处理?这样的话,是不是每次显示的时候都要运算,原来是分成不同的版本存下来的,显示的时候直接调用就好了。

    另外,询问一下,mongoid 上怎么用这个东西?CarrierWave 是有 mongoid 的整合 gem 的。

  • 我在使用 Active_Storage 的时候,遇到了一个奇怪问题。 这么多年来,一直都在使用七牛云,做了设置: storage.yml 里面

    qiniu:
        service: Qiniu
        access_key: <%= Rails.application.credentials.dig(:qiniu, :access_key) %>
        secret_key: <%= Rails.application.credentials.dig(:qiniu, :secret_key) %>
        bucket: <%= Rails.application.credentials.dig(:qiniu, :bucket) %>
        domain: <%= Rails.application.credentials.dig(:qiniu, :domain) %>
    

    development.rb 里面

    config.active_storage.service = :qiniu
    

    _form.html.erb 里面

    <%= form.file_field :image, direct_upload: true%>
    

    在上传文件的时候,却得到了这样的提示:

    NameError (Cannot load `Rails.config.active_storage.service`:
    uninitialized constant ActiveStorage::Service::QiniuService::Qiniu):
    

    使用 local 的时候,没有问题。 七牛的全套设置,是在其他项目里面一直在用的,肯定没有问题。

    请问我少设置了什么吗?

  • 做注释的时候,还没有找到正确的方法。在找到正确方法之后,就把注释取消了。

  • 调整了一下,解决了问题。 先在 application_controller.rb 里面把

    protect_from_forgery with: :exception
    

    注释掉,算是把逻辑调整完成了。

    然后在 js 里面加上了:

    axios.defaults.headers.common['X-CSRF-Token'] = document.getElementsByTagName("meta")[1].content;
    
    

    再恢复 application_controller.rb 里面的

    protect_from_forgery with: :exception
    

    工作正常。

    作为一个把写程序作为业余爱好的业余程序员,经常会遇到很多稀奇古怪的问题,在慢慢解决问题的过程中,寻找乐趣。

  • 是的,应该如何处理呢? 我没有办法取得 $('meta[name="csrf-token"]').attr('content')。 有什么方法可以获得独立的 token 吗?

  • 我原来用的是 ruby2.3 和 rails4.2.3

    新应用用的是 ruby2.4 和 rails5.1.2

    carrierwave-mongoid 0.10.0

  • 我创建了新的应用,将原来应用的 mongodb 数据库备份下来,还原到一个新的数据库上,然后建立了相同的 model,建立了相同的 carrierwave.rb 的配置文件,相同的 Uploader。

    却无法找到相关的文件。

    现在直接将新的应用指向了原来的数据库,依然没有办法找到相关的文件信息。

    不解啊。估计不是数据库的问题,应该是我的配置少了什么东西吧。

  • 感谢,我会去尝试一下。