最近,我将密码验证代码更改为以下代码,以便创建不需要密码和密码确认的表单如何在 Rails 中使用 form_for 仅更改模型中的一个属性。
请注意,我没有使用 has_secure_password 来生成我的加密密码。我在 RailsTutorial 中使用了每个 Hartl 的 SHA2.hexdigest。
用户.rb
before_save :encrypt_password, :unless => Proc.new { |u| u.password.blank? }
validates_presence_of :password, :if => :should_validate_password?
validates_confirmation_of :password, :if => :should_validate_password?
validates_length_of :password, :minimum => 6, :maximum => 40, :allow_blank => true
#changing :allow_blank from false to true above fixed my problem.
def should_validate_password?
updating_password || new_record?
end
我在记住我/重置密码http://railscasts.com/episodes/274-remember-me-reset-password上关注了这个 Railscast ,但我一直收到这个错误:
ActiveRecord::RecordInvalid in PasswordResetsController#create
Validation failed: Password is too short (minimum is 6 characters)
当我尝试为现有用户生成 auth_tokens 以及尝试提交我的电子邮件以获取重置链接时,就会发生这种情况。我可以通过注释掉这段代码来暂时删除这个验证,一切正常。
我尝试重新登录用户帐户以更改密码,使其在范围内(9 个字符长),但我仍然收到相同长度的验证错误消息。
有小费吗?
我不知道问题出在哪里。我不明白为什么要验证我的密码。
这是我在密码重置控制器中的创建操作:
def create
user = User.find_by_email(params[:email])
user.send_password_reset if user
redirect_to root_path, :notice => "Email sent with password reset"
end
这是我的密码重置表格:
<%= form_tag password_resets_path, :method => :post do %>
<div class="field">
<%= label_tag :email %>
<%= text_field_tag :email, params[:email] %>
</div>
<div class="actions"><%= submit_tag "Reset Password" %></div>
<% end %>
让我知道你们是否需要任何其他文件。
编辑:使用工作解决方案对代码进行了更改。
谢谢。