Symfony2 $user-gt;setPassword() updates password as plain text [DataFixtures + FOSUserBundle](Symfony2 $user-setPassword() 将密码更新为纯文本 [DataFixtures + FOSUserBundle])
问题描述
我正在尝试使用一些用户对象预填充数据库,但是当我调用 $user->setPassword('some-password');
然后保存用户对象时,字符串some-password"直接存储在数据库中,而不是散列+加盐密码.
I'm trying to pre-populate a database with some User objects, but when I call $user->setPassword('some-password');
and then save the user object, the string 'some-password' is stored directly in the database, instead of the hashed+salted password.
我的 DataFixture 类:
My DataFixture class:
// Acme/SecurityBundle/DataFixtures/ORM/LoadUserData.php
<?php
namespace AcmeSecurityBundleDataFixturesORM;
use DoctrineCommonDataFixturesFixtureInterface;
use DoctrineCommonPersistenceObjectManager;
use AcmeSecurityBundleEntityUser;
class LoadUserData implements FixtureInterface
{
public function load(ObjectManager $manager)
{
$userAdmin = new User();
$userAdmin->setUsername('System');
$userAdmin->setEmail('system@example.com');
$userAdmin->setPassword('test');
$manager->persist($userAdmin);
$manager->flush();
}
}
以及相关的数据库输出:
And the relevant database output:
id username email salt password
1 System system@example.com 3f92m2tqa2kg8cookg84s4sow80880g test
推荐答案
由于你使用的是 FOSUserBundle,你可以使用 UserManager
来做到这一点.我会使用这段代码(假设你设置了 $this->container
):
Since you are using FOSUserBundle, you can use UserManager
to do this. I would use this code (assuming you have $this->container
set):
public function load(ObjectManager $manager)
{
$userManager = $this->container->get('fos_user.user_manager');
$userAdmin = $userManager->createUser();
$userAdmin->setUsername('System');
$userAdmin->setEmail('system@example.com');
$userAdmin->setPlainPassword('test');
$userAdmin->setEnabled(true);
$userManager->updateUser($userAdmin, true);
}
这篇关于Symfony2 $user->setPassword() 将密码更新为纯文本 [DataFixtures + FOSUserBundle]的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Symfony2 $user->setPassword() 将密码更新为纯文本 [DataFixtures + FOSUserBundle]


- Oracle 即时客户端 DYLD_LIBRARY_PATH 错误 2022-01-01
- 正确分离 PHP 中的逻辑/样式 2021-01-01
- SoapClient 设置自定义 HTTP Header 2021-01-01
- Mod使用GET变量将子域重写为PHP 2021-01-01
- 没有作曲家的 PSR4 自动加载 2022-01-01
- 如何定位 php.ini 文件 (xampp) 2022-01-01
- PHP Count 布尔数组中真值的数量 2021-01-01
- 带有通配符的 Laravel 验证器 2021-01-01
- Laravel 仓库 2022-01-01
- 从 PHP 中的输入表单获取日期 2022-01-01