首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sfDoctrineGuardPluggin在数据转储后从夹具重新散列密码。

sfDoctrineGuardPluggin在数据转储后从夹具重新散列密码。
EN

Stack Overflow用户
提问于 2011-07-25 09:29:21
回答 1查看 150关注 0票数 3

我有Doctrine和sfDoctrineGuardPlugin的symfony 1.4。

我遇到了加载夹具 for sfGuardUser的问题,它是由symfony原则:data-dump制作的。

问题的核心是夹具文件中的密码不是加密的,在夹具加载过程中会对其进行加密。

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

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

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-07-25 10:39:25

旧塞福尼论坛中有一个解决方案。

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

代码语言:javascript
复制
  public function setEncryptedPassword($v)
  {
    if ($v !== null) {
        $v = (string) $v;
    }

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

    return $this;
  }

在转储中,将所有password发生更改为encrypted_password

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6814101

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档