密码摘要不能为空

时间:2014-03-14 20:32:35

标签: ruby-on-rails ruby activerecord bcrypt

Ruby on Rails 3.2

我的表单正在创建一个新的经销商。我添加了gem 'bcrypt-ruby', '3.0.1',我的数据库表有password_digest: string,我的模型有:password, :password_confirmation,has_secure_password

当我提交表单时,我得到的错误是Password digest can't be blank

这是POST的内容:

Started POST "/distributors" for x.x.x.x at 2014-03-14 12:59:07 -0700
Processing by DistributorsController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"x=", "distributor"=>{"company_name"=>"First Account", "company_website
"=>"First.com", "contact_name"=>"First", "contact_email"=>"first@moon.com", "contact_title"=>"owner", "company_phone"=>"555-665-5555", "company_region"=>"Asia Paci
fic", "company_address"=>"172 E Center Street", "company_country"=>"Cambodia", "company_city"=>"Covina", "company_state"=>"Not Applicable", "company_zip"=>"01970",
"sales_contact_name"=>"Bob", "sales_contact_email"=>"bobby@moon.com", "tech_contact_name"=>"Steph", "tech_contact_email"=>"steph@moon.com", "additional_name"=>"",
"additional_email"=>"", "additional_name2"=>"", "additional_email2"=>"", "area_served"=>["", "Bangladesh"], "terms_and_conditions"=>"1"}, "commit"=>"Register"}
Distributor Load (0.1ms)  SELECT `distributors`.* FROM `distributors` WHERE `distributors`.`contact_email` = 'first@moon.com' LIMIT 1
(0.1ms)  BEGIN
Distributor Exists (0.2ms)  SELECT 1 AS one FROM `distributors` WHERE `distributors`.`contact_email` = 'first@moon.com' LIMIT 1
(0.1ms)  ROLLBACK

有人知道我错过了什么吗?谢谢

2 个答案:

答案 0 :(得分:1)

您的日志缺少正在设置的密码和password_confirmation字段。它应该看起来更像这个

{"utf8"=>"✓", "authenticity_token"=>"dsdfhjdskhfsdfhjsdfhjsdfhjdsfhjsdfE=", "user"=>{"email"=>"email@provider.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Register"}

答案 1 :(得分:1)

您发布到distributors路由的哈希不包含任何有关密码的信息。使用您编写的代码无法创建没有密码的经销商。所以错误信息是完全正确的。

您需要在网页中添加passwordpassword_confirmation字段。

相关问题