ruby-on-rails - Rails API,Cloudinary:未初始化的常量 CLOUDINARY_CLOUD_NAME (NameError)
问题描述
我一直在我的 Rails API 中上传和删除 Cloudinary 上的图像,直到我开始收到主题错误。我无法启动并运行服务器。
任何想法是什么原因造成的?
我安装了 cloudinary gem,并在 config/initializers/cloudinary.rb 中有我的配置,我的凭据在 application.yml 中:
Cloudinary.config do |config|
config.cloud_name = ENV[CLOUDINARY_CLOUD_NAME]
config.api_key = ENV[CLOUDINARY_API_KEY]
config.api_secret = ENV[CLOUDINARY_API_SECRET]
config.secure = true
config.cdn_subdomain = true
end
我在我的图像控制器中引用 Cloudinary,如下所示:
result = Cloudinary::Uploader.upload(image, options = {})
这是完整的错误:
*** 作为更新,我将 cloudinary url 放在了我的 application.yml 中并注释掉了 cloudinary.rb,它现在可以工作了,但是如果有人能解释为什么会出现未初始化的常量错误,我将不胜感激。****
/Users/ok/live-projects/a-pj-api/config/initializers/cloudinary.rb:2:in `block in <top (required)>': uninitialized constant CLOUDINARY_CLOUD_NAME (NameError)
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/cloudinary-1.9.1/lib/cloudinary.rb:82:in `config'
from /Users/ok/live-projects/a-pj-api/config/initializers/cloudinary.rb:1:in `<top (required)>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/engine.rb:655:in `block in load_config_initializer'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/activesupport-5.1.5/lib/active_support/notifications.rb:168:in `instrument'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/engine.rb:654:in `load_config_initializer'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/engine.rb:612:in `block (2 levels) in <class:Engine>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/engine.rb:611:in `each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/engine.rb:611:in `block in <class:Engine>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:30:in `instance_exec'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:30:in `run'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:59:in `block in run_initializers'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:228:in `block in tsort_each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:350:in `block (2 levels) in each_strongly_connected_component'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:422:in `block (2 levels) in each_strongly_connected_component_from'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:431:in `each_strongly_connected_component_from'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:421:in `block in each_strongly_connected_component_from'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:48:in `each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:48:in `tsort_each_child'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:415:in `call'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:415:in `each_strongly_connected_component_from'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:349:in `block in each_strongly_connected_component'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:347:in `each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:347:in `call'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:347:in `each_strongly_connected_component'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:226:in `tsort_each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/tsort.rb:205:in `tsort_each'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/initializable.rb:58:in `run_initializers'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/application.rb:353:in `initialize!'
from /Users/okadachikara/live-projects/apartment-pj-api/config/environment.rb:5:in `<top (required)>'
from config.ru:3:in `require_relative'
from config.ru:3:in `block in <main>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/builder.rb:55:in `instance_eval'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/builder.rb:55:in `initialize'
from config.ru:in `new'
from config.ru:in `<main>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/builder.rb:49:in `eval'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/builder.rb:49:in `new_from_string'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/builder.rb:40:in `parse_file'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/server.rb:319:in `build_app_and_options_from_config'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/server.rb:219:in `app'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:24:in `app'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/rack-2.0.4/lib/rack/server.rb:354:in `wrapped_app'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:80:in `log_to_stdout'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:42:in `start'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:135:in `block in perform'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:130:in `tap'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands/server/server_command.rb:130:in `perform'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/thor-0.20.0/lib/thor/command.rb:27:in `run'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/thor-0.20.0/lib/thor/invocation.rb:126:in `invoke_command'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/thor-0.20.0/lib/thor.rb:387:in `dispatch'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/command/base.rb:63:in `perform'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/command.rb:44:in `invoke'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/railties-5.1.5/lib/rails/commands.rb:16:in `<top (required)>'
from /Users/ok/live-projects/a-pj-api/bin/rails:9:in `require'
from /Users/ok/live-projects/ap-pj-api/bin/rails:9:in `<top (required)>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/client/rails.rb:28:in `load'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/client/rails.rb:28:in `call'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/client/command.rb:7:in `call'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/client.rb:30:in `run'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/bin/spring:49:in `<top (required)>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/binstub.rb:31:in `load'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/gems/2.4.0/gems/spring-2.0.2/lib/spring/binstub.rb:31:in `<top (required)>'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/rubygems/core_ext/kernel_require.rb:68:in `require'
from /usr/local/opt/rbenv/versions/2.4.2/lib/ruby/2.4.0/rubygems/core_ext/kernel_require.rb:68:in `require'
from /Users/ok/live-projects/ap-pj-api/bin/spring:15:in `<top (required)>'
from ./bin/rails:3:in `load'
from ./bin/rails:3:in `<main>'
解决方案
从共享的规范看来,您没有指定环境变量,而是将变量作为常量提及。
将代码更改为以下提到的:
Cloudinary.config do |config|
config.cloud_name = ENV["CLOUDINARY_CLOUD_NAME"]
config.api_key = ENV["CLOUDINARY_API_KEY"]
config.api_secret = ENV["CLOUDINARY_API_SECRET"]
config.secure = true
config.cdn_subdomain = true
end
推荐阅读
- firebase - 了解使用 firebase 登录 facebook 的行为
- r - 如何使用 sparklyr 行绑定两个 Spark 数据帧?
- javascript - 无法在 React Native IOS 中解析模块,但可以在 Android 中使用
- javascript - 当用户按下一个键时遍历“下拉”元素
- javascript - 当我点击提交时增加字段 user.entries
- c# - 当试图调用 GetComponent<>() 我的类“库存”返回为空
- coldfusion - 使用 ColdFusion 从 URL 中提取域
- python - CSV 类阅读器没有获得实际图像
- python - 将代码拆分为模块(约定)
- azure - Azure CosmosDB 延续令牌结构