【发布时间】:2012-04-14 03:41:11
【问题描述】:
我的表格包含以下字段:email、password_hash 和 salt。
在用户注册时,我想验证密码和密码确认,但我总是收到can't be blank 输入密码的错误。
这是我的模型:
attr_accessor :password
validates :password, :presence => true,
:confirmation => true,
:length => { :within => 6..40 }
我来宾我无法验证不是数据库的字段,但是如何对用户输入的密码进行验证?
我在数据库中没有密码字段,因为我加密了 password 输入,然后将其存储在 db password_hash 字段中。
编辑:
这是数据库表:
class CreateStudents < ActiveRecord::Migration
def change
create_table :students do |t|
t.string :first_name
t.string :last_name
t.string :email
t.string :password_hash
t.string :salt
t.boolean :activated
t.timestamps
end
end
end
这是注册视图:
<%= form_for @student, url: {action: 'create'} do |form| %>
<p style="font-size:smaller; color:red">
<% @student.errors.messages.each do |att, msg| %>
<%= msg[0] %><br>
<% end %>
<p>
<%= form.label :first_name %><br>
<%= form.text_field :first_name %>
<p>
<%= form.label :last_name %><br>
<%= form.text_field :last_name %>
<p>
<%= form.label :email %><br>
<%= form.text_field :email %>
<p>
<%= form.label :password %><br>
<%= form.password_field :password %>
<p>
<%= form.label :password_confirmation %><br>
<%= form.password_field :password_confirmation %>
<p>
<%= form.submit %>
<% end %>
这是控制器:
def sing_up
@student = Student.new
render 'sing_up'
end
def create
@student = Student.new
@student.first_name = params[:student][:first_name]
@student.last_name = params[:student][:last_name]
@student.email = params[:student][:email]
@student.salt = BCrypt::Engine.generate_salt
@student.password_hash = BCrypt::Engine.hash_secret(params[:student][:password], @student.salt)
if @student.save
redirect_to controller: 'singups', action: 'index'
else
render 'sing_up'
end
end
最后,这是模特
class Student < ActiveRecord::Base
attr_accessor :password
validates :first_name, :length => { minimum: 3, message: "first_name" }
validates :last_name, :length => { minimum: 3, message: "last_name" }
validates :email, :presence => { message: 'email' },
:format => { with: /\A[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]+\z/ , message: 'email format' },
:uniqueness => { message: 'uniqueness?' }
validates :password, :confirmation => { message: 'password' },
:length => { minimum: 6, message: 'password length' }
end
每次用户输入密码时,无论密码是什么,第一次验证 :confirmation => { message: 'password' } 都会失败。
如果我删除 validates :password 部分,一切正常,但用户输入的密码未经过验证。
【问题讨论】:
-
请添加您的表单代码。我怀疑您在表单中使用了
password_hash,而您什么时候应该使用password?是的,您可以验证任何字段,无论它是否是数据库列。 -
我添加了更多信息,以便您查看。
标签: ruby-on-rails