gpt4 book ai didi

symfony1 - sfDoctrineGuardPlugin 在数据转储后从 fixture 重新散列密码

转载 作者:行者123 更新时间:2023-12-01 13:00:07 24 4
gpt4 key购买 nike

我有带有 Doctrine 和 sfDoctrineGuardPlugin 的 symfony 1.4。

我在为 sfGuardUser loading fixtures 时遇到问题,它来自 symfony doctrine:data-dump

问题的核心是fixture文件中的密码没有加密,在fixture加载的过程中会被加密。

另一方面 - 当我们从数据库中转储数据时,密码已经加密,如果我们再次尝试加载它们,密码的值将被第二次重新哈希 .

有人知道如何避免这种情况吗?

我正在使用这个过程来防止在需要更改模型时丢失数据。如果有人知道这个特定问题的其他解决方案,我将不胜感激!

最佳答案

old symfony forum 中有一个解决方案.

简而言之:在您的用户模型中创建一个 setEncryptedPassword 函数,如下所示:

  public function setEncryptedPassword($v)
{
if ($v !== null) {
$v = (string) $v;
}

if ($this->password !== $v) {
parent::_set('password', $v);
}

return $this;
}

并且在您的转储中将所有出现的 password 更改为 encrypted_pa​​ssword

关于symfony1 - sfDoctrineGuardPlugin 在数据转储后从 fixture 重新散列密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6814101/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com