草庐IT

password

全部标签

Ruby BCrypt 哈希比较

我正在尝试使用Sinatra和BCrypt实现看似非常简单的身份验证方法,但显然我遗漏了一些东西......用户预先分配了一个临时密码,该密码以明文形式存储在数据库中。我根据临时密码进行身份验证,然后创建一个salt和password_hash,并将它们作为字符串写入数据库(在本例中为mongo)。为了进行身份验证,我从数据库和用户密码中获取盐以进行比较。post"/password_reset"douser=User.first(:email=>params[:email],:temp_password=>params[:temp_password])ifdealer!=nilthe

ruby-on-rails - 在rails 4中设计用户模型中保存自定义字段

我设计了一个用户模型并向其添加了额外的字段。当我创建和帐户时,一切正常,只有电子邮件、pw和pwconf。然后我想让用户进入编辑页面并填写可选的附加字段。但是,当他们提交时,所有内容都保存为nil。classRegistrationsControllertruerespond_withresource,:location=>after_update_path_for(resource)elseclean_up_passwordsresourcerespond_withresourceendenddefuser_paramsparams.require(:user).permit(:em

ruby-on-rails - salt 如何在 Rails 的 has_secure_password 中工作

据我所知,为了使加密密码更安全,我会生成一个随机数(盐)并将其与散列密码一起存储在用户记录中(例如。)我会连接盐使用明文密码,然后对其进行加密(哈希)。生成的哈希将更难破解。将重复此过程以验证密码。查看has_secure_password和bcrypt_ruby(披露:我不是安全专家)我不知道这是如何完成的,因为用户记录中唯一存储的是散列密码。盐在哪里? 最佳答案 密码哈希和盐保存在数据库中名为password_digest的字符串列中。看这个question. 关于ruby-on-r

ruby - 试图理解 self.method_name 与 Classname.method_name 在 Ruby 中的使用

我试图了解何时使用self.method_name与何时使用Classname.method_name。在下面的示例中,为什么“before_create”需要引用“User.hash_password”而不是“self.hash_password”或只是“hash_password”?由于我们已经在User类中,我认为before_create方法会“知道”“hash_password”是它自己的类的成员,不需要任何特殊语法来引用它。require'digest/sha1'classUser["name=?andhashed_password=?",name,hashed_passw

ruby - Rails—— self 与@

我正在学习MichaelHartl的RoR教程,它涵盖了密码加密的基础知识。这是当前的用户模型:classUsertrue,:length=>{:maximum=>50}validates:email,:presence=>true,:format=>{:with=>email_regex},:uniqueness=>{:case_sensitive=>false}validates:password,:presence=>true,:length=>{:maximum=>20,:minimum=>6},:confirmation=>truebefore_save:encrypt_pa

ruby-on-rails - 名称错误 : uninitialized constant Faker

我正在尝试在Rails4中为我的数据库运行一个简单的bundleexecrakedb:seed。但是,在运行它时,我得到以下输出:********-C02MGBVJFD57:myapp***********$bundleexecrakedb:seedYourGemfileliststhegemfactory_girl_rails(>=0)morethanonce.Youshouldprobablykeeponlyoneofthem.Whileit'snotaproblemnow,itcouldcauseerrorsifyouchangetheversionofjustoneofthem

ruby-on-rails - 如何跳过 has_secure_password 验证

在我的应用中,只有管理员可以创建新的用户记录。用户会通过电子邮件收到一个激活链接,他们可以在其中设置密码。我想使用has_secure_passord方法(railscast):classUser效果很好,但它会自动验证密码摘要的存在...所以当管理员创建记录时,验证失败。我有办法只跳过自动添加的password_digest验证而不跳过我添加的其他验证吗? 最佳答案 从4.X版本的rails开始,has_secure_password采用一个选项:validations。如果将其设置为false,它将不会运行验证。gem3.X版本

ruby-on-rails - 如何更改 "Devise: password reset instruction email' 的主题”

我只是无法更改“密码重置说明”电子邮件的主题。我更改了Mailer中的notifer.rb以覆盖Devise默认电子邮件主题。但它不起作用。在我的应用程序中,Devise.yml文件中有默认的电子邮件主题。但我想通过从数据库中提取数据来动态更改它。 最佳答案 可以在intilizer目录下的devise.en.yml文件中修改并为任何邮件设置您自己的主题mailer:confirmation_instructions:subject:'Confirmationinstructions'reset_password_instructi

ruby-on-rails - 尝试为 ror 应用程序设置 postgres,出现错误 - fe_sendauth : no password supplied

获得:Anerrorhasoccurred:Errorconnectingtotheserver:fe_sendauth:nopasswordsupplieddatabase.yml中的设置与其他机器上的应用设置相同。我如何设置才能不需要硬编码密码?我可以使用PgAdmin-III查看数据库。我宁愿不要在database.yml中设置密码,因为使用此应用程序的其他机器没有/不需要密码,所以这似乎与我的Pg安装有关。 最佳答案 您需要更改您的pg_hba.conf。这是我的一个例子:pg_hba.conf:TYPEDATABASEUS

ruby-on-rails - 工厂未注册

我想用RSpec测试一个模型,但我可能偶然发现了一个我找不到的拼写错误。有人可以帮我一下吗?我已经为此苦苦挣扎了很长时间,就是找不到任何错误。提前致谢!用户规范.rbrequire'spec_helper'describeUserdoit"hasavalidfactory"doFactoryGirl.build(:user).shouldbe_validendit"isinvalidwithoutane-mail"it"isinvalidwithoutacorrecte-mail"it"isinvalidwithoutapassword"it"isinvalidwithoutamatc