Heroku ArgumentError(不是公认的提供者)

时间:2015-10-13 19:58:50

标签: ruby-on-rails heroku paperclip fog

我正在尝试使用Paperclip和Fog gem将个人资料图片上传到Google Cloud。到目前为止这就是我所拥有的

在我的Gemfile中

gem "paperclip", git: "git://github.com/thoughtbot/paperclip.git"
gem 'fog'

在我的用户模型中

has_attached_file   :avatar,
                      styles: {:big => "200x200>", thumb: "50x50>"},
                      storage: :fog,
                      fog_credentials: "#{Rails.root}/config/gce.yml",
                      fog_directory: "google-bucket-name"

  validates_attachment_content_type :avatar, content_type: /\Aimage\/.*\Z/

当我在本地运行时,我可以将其上传到谷歌。但是,当我尝试在Heroku上执行此操作时,我收到此错误

015-10-13T19:47:15.703642+00:00 app[web.1]:   SQL (2.1ms)  UPDATE "users" SET "avatar_file_name" = $1, "avatar_content_type" = $2, "avatar_file_size" = $3, "avatar_updated_at" = $4, "updated_at" = $5 WHERE "users"."id" = $6  [["avatar_file_name", "3.jpeg"], ["avatar_content_type", "image/jpeg"], ["avatar_file_size", 8587], ["avatar_updated_at", "2015-10-13 19:47:15.140362"], ["updated_at", "2015-10-13 19:47:15.695467"], ["id", 3]]
2015-10-13T19:47:15.707684+00:00 app[web.1]:    (0.9ms)  ROLLBACK
2015-10-13T19:47:15.711451+00:00 app[web.1]: F, [2015-10-13T19:47:15.711260 #3] FATAL -- :
2015-10-13T19:47:15.711457+00:00 app[web.1]: ArgumentError ( is not a recognized provider):
2015-10-13T19:47:15.711459+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/gems/fog-core-1.32.1/lib/fog/core/services_mixin.rb:12:in `new'
2015-10-13T19:47:15.711461+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/gems/fog-core-1.32.1/lib/fog/storage.rb:22:in `new'
2015-10-13T19:47:15.711463+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/bundler/gems/paperclip-8339e0fce5d8/lib/paperclip/storage/fog.rb:217:in `connection'
2015-10-13T19:47:15.711465+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/bundler/gems/paperclip-8339e0fce5d8/lib/paperclip/storage/fog.rb:227:in `directory'
2015-10-13T19:47:15.711468+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/bundler/gems/paperclip-8339e0fce5d8/lib/paperclip/storage/fog.rb:101:in `block in flush_writes'
2015-10-13T19:47:15.711470+00:00 app[web.1]:   vendor/bundle/ruby/2.1.0/bundler/gems/paperclip-

不确定发生了什么。

1 个答案:

答案 0 :(得分:0)

经过大量调试后,我的 fog_credentials 哈希未按预期在heroku上进行。我没有传递“#{Rails.root} /config/gce.yml”,而是这样做。

has_attached_file   :avatar,
                      styles: {:big => "200x200>", thumb: "50x50>"},
                      storage: :fog,
                      fog_credentials: { aws_access_key_id: '<your_access_id>'
                                         aws_secret_access_key: '<your secret>'
                                         provider: 'Google' },
                      fog_directory: "google-bucket-name"

  validates_attachment_content_type :avatar, content_type: /\Aimage\/.*\Z/