我想知道如何将自定义配置变量添加到Rails应用程序,以及如何在控制器中访问它们?
其次,我计划在我的应用程序中有S3支持上传,如果我想添加一个具有S3访问权限的yaml文件,秘密密钥,我如何在我的Rails应用程序中初始化它,以及如何访问我在配置文件中定义的值。
我想知道如何将自定义配置变量添加到Rails应用程序,以及如何在控制器中访问它们?
其次,我计划在我的应用程序中有S3支持上传,如果我想添加一个具有S3访问权限的yaml文件,秘密密钥,我如何在我的Rails应用程序中初始化它,以及如何访问我在配置文件中定义的值。
当前回答
我将建议如何处理应用程序中的配置的好方法。有三个基本规则:
改变你的配置而不是代码; 在条件下使用配置; 编写有意义的代码。
要获得更详细的概述,请参见以下链接:以正确的方式配置Rails
其他回答
我将建议如何处理应用程序中的配置的好方法。有三个基本规则:
改变你的配置而不是代码; 在条件下使用配置; 编写有意义的代码。
要获得更详细的概述,请参见以下链接:以正确的方式配置Rails
从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,然后在生产控制台中使用实际的生产值编辑示例文件。
看看这个整洁的宝石,正是这样做的: https://github.com/mislav/choices
这样,您的敏感数据就不会暴露在开源项目中
我真的很喜欢设置逻辑宝石。非常容易设置和使用。
https://github.com/binarylogic/settingslogic
我们在工作中开始做的是ActiveSupport Ordered Hash
它允许你在环境文件中清晰地定义你的配置。
config.service = ActiveSupport::OrderedOptions.new
config.service.api_key = ENV['SERVICE_API_KEY']
config.service.shared_secret = ENV['SERVICE_SHARED_SECRET']