Rails model: before_save {self.password = password.strip} vs



我的用户模型中有几行可以从用户的电子邮件和密码中去掉前导/尾随空格。原始代码如下所示:

before_save {self.email = email.strip}
before_save {self.password = password.strip}
before_save {self.password_confirmation = password_confirmation.strip}

这通过了我的测试:

test "password entry should ignore leading/tailing whitespace" do
 @user = User.create(name: "M", email: " foo@bar.com", 
  password: "  password", password_confirmation: "  password")
 assert @user.authenticate("password")
 assert_not @user.authenticate(" password")
end

现在我试着重新考虑一下:

before_save {email.strip!}
before_save {password.strip!}
before_save {password_confirmation.strip!}

这对我的电子邮件测试来说很好,但它破坏了上面的密码测试。那么,问题是,原始版本与重新分解的代码实际上有何不同?

您不能使用password.strip!,因为实际上没有password这样的字段——它是一个生成和存储密码哈希的setter password=

相关内容

最新更新