我想知道如何将自定义配置变量添加到Rails应用程序,以及如何在控制器中访问它们?
其次,我计划在我的应用程序中有S3支持上传,如果我想添加一个具有S3访问权限的yaml文件,秘密密钥,我如何在我的Rails应用程序中初始化它,以及如何访问我在配置文件中定义的值。
我想知道如何将自定义配置变量添加到Rails应用程序,以及如何在控制器中访问它们?
其次,我计划在我的应用程序中有S3支持上传,如果我想添加一个具有S3访问权限的yaml文件,秘密密钥,我如何在我的Rails应用程序中初始化它,以及如何访问我在配置文件中定义的值。
更新1
非常推荐:我现在正在使用Rails Config gem,因为它提供了细粒度的控制。
更新2
如果你想要一个快速的解决方案,那么看看下面杰克·普拉特的答案。
虽然我下面最初的答案仍然有效,但这个答案现在已经过时了。我建议查看更新1和更新2。
最初的回答:
对于快速解决方案,观看Ryan Bates的“YAML配置文件”屏幕会很有帮助。
总而言之:
# config/initializers/load_config.rb
APP_CONFIG = YAML.load_file("#{Rails.root}/config/config.yml")[Rails.env]
# application.rb
if APP_CONFIG['perform_authentication']
# Do stuff
end
在Rails 3中,特定于应用程序的自定义配置数据可以放置在应用程序配置对象中。配置可以在初始化文件或环境文件中分配——例如对于给定的应用程序MyApp:
MyApp::Application.config.custom_config_variable = :my_config_setting
or
Rails.configuration.custom_config_variable = :my_config_setting
要读取设置,只需调用配置变量而不设置它:
Rails.configuration.custom_config_variable
=> :my_config_setting
UPDATE Rails 4
在Rails 4中,有一个新的方法=> http://guides.rubyonrails.org/configuring.html#custom-configuration
在Rails 3.0.5中,以下方法对我来说是有效的:
在config /环境/发展。rb,写
config.custom_config_key = :config_value
值custom_config_key然后可以从其他文件引用
Rails.application.config.custom_config_key
我创建了一个简单的YAML设置插件:Yettings
它的工作方式与khell回答中的代码类似,但你只需要添加这个YAML配置文件:
app/config/yetting.yml
这个插件动态创建了一个类,允许你在你的应用程序中访问YML设置作为类方法,如下所示:
Yetting.your_setting
此外,如果你想使用多个具有唯一名称的设置文件,你可以将它们放在app/config内的子目录中,如下所示:
app/config/yettings/first.yml
app/config/yettings/second.yml
然后你可以像这样访问这些值:
FirstYetting.your_setting
SecondYetting.your_setting
它还为您提供了可以覆盖每个环境的默认设置。你也可以在yml文件中使用erb。
这适用于rails 3.1:
在config /环境。Rb(或在config/environments/..以特定环境为目标):
YourApp::Application.config.yourKey = 'foo'
这将在控制器或视图中访问,如下所示:
YourApp::Application.config.yourKey
(YourApp应替换为您的应用程序名称。)
注意:它是Ruby代码,所以如果你有很多配置键,你可以这样做:
在config /环境。rb:
YourApp::Application.configure do
config.something = foo
config.....
config....
.
config....
end
我将建议如何处理应用程序中的配置的好方法。有三个基本规则:
改变你的配置而不是代码; 在条件下使用配置; 编写有意义的代码。
要获得更详细的概述,请参见以下链接:以正确的方式配置Rails
我只是想更新Rails 4.2中最新的很酷的东西,你现在可以在你的config/**/*中做这个。rb文件:
config.x.whatever.you.want = 42
...这将在你的应用程序中可用:
Rails.configuration.x.whatever.you.want
更多信息请访问:http://guides.rubyonrails.org/configuring.html#custom-configuration
从Rails 4.2开始,没有额外的宝石,你可以加载config/hi。简单地使用Rails.application。config_for:嗨。
例如:
触控配置/ passwords.yml #配置/ passwords.yml 发展: 用户名:‘一个’ 密码:“b” 生产: 用户名:“aa” 密码:“bb”
配置初始化/ constants.rb联系 #配置/初始化/ constants.rb AUTHENTICATION = Rails.application。config_for:密码
现在你可以在应用程序的任何地方使用AUTHENTICATION常量: #rails c生产 :001> AUTHENTICATION['username'] => 'aa' 然后添加密码。Yml到。gitignore: echo /config/passwords。Yml >> .gitignore,为你的cp /config/密码创建一个示例文件。yml / config / passwords.example。Yml,然后在生产控制台中使用实际的生产值编辑示例文件。
In Rails 4
假设你把你的自定义变量放到一个yaml文件中:
# config/acme.yml
development:
:api_user: 'joe'
:api_pass: 's4cret'
:timeout: 20
创建一个初始化式来加载它们:
# config/initializers/acme.rb
acme_config = Rails.application.config_for :acme
Rails.application.configure do
config.acme = ActiveSupport::OrderedOptions.new
config.acme.api_user = acme_config[:api_user]
config.acme.api_pass = acme_config[:api_pass]
config.acme.timeout = acme_config[:timeout]
end
现在,在你的应用程序的任何地方,你都可以像这样访问这些值:
Rails.configuration.acme.api_user
Rails.application非常方便。Config_for:acme将加载你的acme。Yml和使用正确的环境。
我们在工作中开始做的是ActiveSupport Ordered Hash
它允许你在环境文件中清晰地定义你的配置。
config.service = ActiveSupport::OrderedOptions.new
config.service.api_key = ENV['SERVICE_API_KEY']
config.service.shared_secret = ENV['SERVICE_SHARED_SECRET']
Rails 6和7
许多过时的答案,所以添加一个特定于Rails 6的答案。
应用程序特定的配置放在初始化文件中。详细信息在这里:边缘指南
例子:
配置/初始化/ foo.rb
module MyApp
class Application < Rails::Application
config.test_val = 'foo'
end
end
另外:
Rails.application.config.test_val = 'foo'
现在可以通过以下方式访问:
Rails.configuration.test_val
更多的可能性。 边缘指南#自定义配置
例如,你也可以设置嵌套的命名空间配置:
config.x.payment_processing.schedule = :daily
config.x.payment_processing.retries = 3
config.super_debugger = true
或者使用config_for加载整个自定义配置文件:
配置/ payment.yml
production:
environment: production
merchant_id: production_merchant_id
public_key: production_public_key
private_key: production_private_key
development:
environment: sandbox
merchant_id: development_merchant_id
public_key: development_public_key
private_key: development_private_key
然后加载:
配置/初始化/ load_payment.rb
module MyApp
class Application < Rails::Application
config.payment = config_for(:payment)
end
end