0

我是 FOSUserBundle 的新手,我已经为这个错误苦苦挣扎了几个小时......并且在网站上找不到合适的答案。

任何人都可以帮助我吗?:-*

这是我的子用户实体

<?php
// src/Blogger/BlogBundle/Entity/CommonUser.php

namespace Blogger\BlogBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use FOS\UserBundle\Model\User as BaseUser;


/**
 * @ORM\Entity(repositoryClass="Blogger\BlogBundle\Entity\Repository\CommonUserRepository")
 * @ORM\Table(name="CommonUser")
 * @ORM\HasLifecycleCallbacks
 */
class CommonUser extends BaseUser
{

    /**
     * @ORM\OneToMany(targetEntity="Request", mappedBy="commonUser")
     */
    protected $requests;



    public function __construct()
    {
        parent::__construct();

        $this->requests = new ArrayCollection();


    }



    /**
     * @ORM\Id
     * @ORM\Column(type="integer", nullable=false)
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;


...
...
...

    /**
     * Get id
     *
     * @return integer
     */
    public function getId()
    {
        return $this->id;
    }


    public function getSalt()
    {
        return '';
    }
...

}

这也是 request.php 类

<?php
// src/Blogger/BlogBundle/Entity/Request.php

namespace Blogger\BlogBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use Blogger\BlogBundle\Entity\Repository\RequestRepository;
/**
 * @ORM\Entity(repositoryClass="Blogger\BlogBundle\Entity\Repository\requestRepository")
 * @ORM\Table(name="request")
 * @ORM\HasLifecycleCallbacks
 */
class Request
{

    /**
     * @ORM\OneToMany(targetEntity="Note", mappedBy="request")
     */
    protected $notes;

    public function __construct()
    {
        $this->notes = new ArrayCollection();


        $this->setCreated(new \DateTime());
        $this->setUpdated(new \DateTime());
    }

    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\ManyToOne(targetEntity="CommonUser", inversedBy="requests")
     * @ORM\JoinColumn(name="user_id", referencedColumnName="id")
     */
    protected $commonUser;

    /**
     * @ORM\Column(type="text")
     */
    protected $request;

    ....
    ....
    ....



    /**
     * Get id
     *
     * @return integer
     */
    public function getId()
    {
        return $this->id;
    }

    ....
    ....
    ....
}

这是我的安全文件

# app/config/security.yml
security:
    encoders:
        FOS\UserBundle\Model\UserInterface: sha512

    role_hierarchy:
        ROLE_ADMIN:       ROLE_USER
        ROLE_SUPER_ADMIN: ROLE_ADMIN

    providers:
        fos_userbundle:
            id: fos_user.user_provider.username

    firewalls:
        main:
            pattern: ^/
            form_login:
                provider: fos_userbundle
                csrf_provider: form.csrf_provider
            logout:       true
            anonymous:    true

    access_control:
        - { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
        - { path: ^/admin/, role: ROLE_ADMIN }
4

2 回答 2

1

当您从 FOSUserBundle 向提供的控制器注册时,存储在 DB 中的密码使用 500 次 SHA1 和随机生成的盐进行加密。因此,如果您始终通过函数 getSalt() 返回 "",则密码将永远不会匹配。不要覆盖此功能。

但是,您可以覆盖 FOSUserBundle 中的控制器,更多信息请参见官方文档

public function getSalt()
{
    return '';
}
于 2013-08-25T17:52:14.977 回答
1

只需尝试更新密码。在终端输入:

php fos:user:change-password $username $password

$user用户名和$password新密码在哪里。

于 2015-09-01T22:17:10.797 回答