我有Doctrine和sfDoctrineGuardPlugin的symfony 1.4。
我遇到了加载夹具 for sfGuardUser的问题,它是由symfony原则:data-dump制作的。
问题的核心是夹具文件中的密码不是加密的,在夹具加载过程中会对其进行加密。
另一方面,当我们从数据库中转储数据时,密码已经加密了,如果我们再次加载它们,密码的值将第二次重新哈希()。
有人知道如何避免这种情况吗?
当需要更改模型时,我使用这个过程来防止数据丢失。如果有人知道这个问题的其他解决方案,我会很感激的!
发布于 2011-07-25 10:39:25
在旧塞福尼论坛中有一个解决方案。
简而言之:在用户模型中创建一个setEncryptedPassword函数,如下所示:
public function setEncryptedPassword($v)
{
if ($v !== null) {
$v = (string) $v;
}
if ($this->password !== $v) {
parent::_set('password', $v);
}
return $this;
}在转储中,将所有password发生更改为encrypted_password。
https://stackoverflow.com/questions/6814101
复制相似问题