弃用警告:您没有设置config.secret_key_base

问题描述 投票:44回答:4

运行我的规格时收到此警告。是否有生成secret_key_base的最佳实践,或者任何字符串是否足够(关于安全性问题)?

ruby-on-rails ruby-on-rails-4
4个回答
96
投票

您可能从3.x或以前的版本升级到Rails 4。

首先生成随机密钥值:

$ bundle exec rake secret

然后取出该值并将其放入config/initializers/secret_token.rb

YourApp::Application.config.secret_key_base = 'your-secret'

用您的应用程序名称替换YourApp

here解释了这个原因。

另见http://guides.rubyonrails.org/upgrading_ruby_on_rails.html#config-secrets-yml


6
投票

从4.1开始,您需要使用config/secrets.yml文件。这在http://guides.rubyonrails.org/upgrading_ruby_on_rails.html#config-secrets-yml中讨论过。


4
投票

您只需在config / initializers目录中创建一个secret_token.rb文件。

以下文件的内容:

YourAppNameHere::Application.config.secret_key_base = #type the key you generated with rake secret here

然后保存文件

close your server: 
ctrl c

restart it: rails s

您现在将看到您在上一章中看到的基本rails应用页面(如果您正在使用Hartl的教程)


2
投票

如果你是像我这样的总诺布,请记得将secret_key_base ='whatever'放在单引号内。只是没有引号的复制和粘贴会引发错误:

C:/RailsInstaller/Ruby1.9.3/lib/ruby/gems/1.9.1/gems/activesupport-4.0.8/lib/act ive_support / dependencies.rb:223:在`load'中:C:/ Users / Jeff C / documents / rails_proje cts / first_app / config / initializers / secret_token.rb:1:语法错误,意外tI DENTIFIER,期待$ end(SyntaxError)

© www.soinside.com 2019 - 2024. All rights reserved.