我试图用一些用户对象预填充数据库,但是当我调用$user->setPassword('some-password');
然后保存用户对象时,字符串“some-password”直接存储在数据库中,而不是哈希+盐渍密码。
我的DataFixture类:
// Acme/SecurityBundle/DataFixtures/ORM/LoadUserData.php
<?php
namespace Acme\SecurityBundle\DataFixtures\ORM;
use Doctrine\Common\DataFixtures\FixtureInterface;
use Doctrine\Common\Persistence\ObjectManager;
use Acme\SecurityBundle\Entity\User;
class LoadUserData implements FixtureInterface
{
public function load(ObjectManager $manager)
{
$userAdmin = new User();
$userAdmin->setUsername('System');
$userAdmin->setEmail('[email protected]');
$userAdmin->setPassword('test');
$manager->persist($userAdmin);
$manager->flush();
}
}
以及相关的数据库输出:
id username email salt password
1 System [email protected] 3f92m2tqa2kg8cookg84s4sow80880g test
最佳答案
由于您正在使用FOSUserBundle,因此可以使用UserManager
来执行此操作。我将使用以下代码(假设您设置了$this->container
):
public function load(ObjectManager $manager)
{
$userManager = $this->container->get('fos_user.user_manager');
$userAdmin = $userManager->createUser();
$userAdmin->setUsername('System');
$userAdmin->setEmail('[email protected]');
$userAdmin->setPlainPassword('test');
$userAdmin->setEnabled(true);
$userManager->updateUser($userAdmin, true);
}
关于php - Symfony2 $ user-> setPassword()将密码更新为纯文本[DataFixtures + FOSUserBundle],我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9183368/