0

我对 FOSUserBundle 有疑问。一个已知问题:'Unrecognized field: usernameCanonical for symfony2 FosUserbundle' 当我尝试登录时

在架构更新时,我收到此错误:

Duplicate definition of column 'username' on entity 'Acme\ProjectBundle\Entity\User' in a field or discriminator column mapping. 

仅当我将“FOSUserBundle:~”添加到 config.yml 中的学说映射设置时,我才会收到此错误

我已经尝试了很多解决方案,但我没有解决我的问题:/请帮助我。

我关注了 FOS 的团队:https ://github.com/FriendsOfSymfony/FOSUserBundle/blob/master/Resources/doc/index.md

在一切正常之前...

我有 Symfony 2.1.9

我的 config.yml:

doctrine:
dbal:
    default_connection: default
    connections:
        default:
            driver:   "%database_driver%"
            host:     "%database_host%"
            port:     "%database_port%"
            dbname:   "%database_name%"
            user:     "%database_user%"
            password: "%database_password%"
            charset:  UTF8
        service:
            driver:   "%database_driver2%"
            host:     "%database_host2%"
            port:     "%database_port2%"
            dbname:   "%database_name2%"
            user:     "%database_user2%"
            password: "%database_password2%"
            charset:  UTF8
orm:
    auto_generate_proxy_classes: "%kernel.debug%"
    #auto_mapping: true
    default_entity_manager: default
    entity_managers:
        default:
            metadata_cache_driver: apc
            result_cache_driver: apc
            query_cache_driver: apc
            connection: default
            mappings:
                FOSUserBundle: ~
                AcmeProjectBundle: {type: yml, dir: Resources/config/doctrine/ } #also tried wit '~'
fos_user:
    db_driver: orm # other valid values are 'mongodb', 'couchdb' and 'propel'
    firewall_name: main
    user_class: Acme\ProjectBundle\Entity\User

我的 Acme\ProjectBundle\Entity\User.php:

namespace Acme\ProjectBundle\Entity;

 use FOS\UserBundle\Entity\User as BaseUser;
 use Doctrine\ORM\Mapping as ORM;
 use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
 use Symfony\Component\Validator\Constraints as Assert;
 use Symfony\Component\Security\Core\User\UserInterface;


 class User extends BaseUser implements UserInterface, \Serializable
 {
      const TYPE_ADMIN        = 0;
      const TYPE_USER         = 2;
      const TYPE_ARTIST       = 3;

/**
 * @var string $salt
 */
protected $salt;

/**
 * @var boolean $is_active
 */
private $is_active;
protected $id;


private $name;


protected $username;

protected $email;

/**
 * @var tinyint $type
 */
private $type;


protected $password;


private $description;


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

/**
 * Set name
 *
 * @param string $name
 * @return User
 */
public function setName($name)
{
    $this->name = $name;

    return $this;
}

/**
 * Get name
 *
 * @return string 
 */
public function getName()
{
    return $this->name;
}

/**
 * Set type
 *
 * @param integer $type
 * @return User
 */
public function setType($type)
{
    $this->type = $type;

    return $this;
}

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

/**
 * Set description
 *
 * @param string $description
 * @return User
 */
public function setDescription($description)
{
    $this->description = $description;

    return $this;
}

/**
 * Get description
 *
 * @return string 
 */
public function getDescription()
{
    return $this->description;
}

/**
 * Set username
 *
 * @param string $username
 * @return User
 */
public function setUsername($username)
{
    $this->username = $username;

    return $this;
}

/**
 * Get username
 *
 * @return string 
 */
public function getUsername()
{
    return $this->username;
}

/**
 * Set password
 *
 * @param string $password
 * @return User
 */
public function setPassword($password)
{
    $this->password = $password;

    return $this;
}

/**
 * Get password
 *
 * @return string 
 */
public function getPassword()
{
    return $this->password;
}

/**
 * Set email
 *
 * @param string $email
 * @return User
 */
public function setEmail($email)
{
    $this->email = $email;

    return $this;
}

/**
 * Get email
 *
 * @return string 
 */
public function getEmail()
{
    return $this->email;
}




public function isPasswordName()
{
    return ($this->name != $this->password);
}

public function isPassUsername()
{
    return ($this->password != $this->username);
}
/**
 * @var \DateTime $date
 */
private $date;


/**
 * Set date
 *
 * @param \DateTime $date
 * @return User
 */
public function setDate($date)
{
    $this->date = $date;

    return $this;
}

/**
 * Get date
 *
 * @return \DateTime 
 */
public function getDate()
{
    return $this->date;
}


private $updateDate;


/**
 * Set updateDate
 *
 * @param \DateTime $updateDate
 * @return User
 */
public function setUpdateDate($updateDate)
{
    $this->updateDate = $updateDate;

    return $this;
}

/**
 * Get updateDate
 *
 * @return \DateTime 
 */
public function getUpdateDate()
{
    return $this->updateDate;
}



public function setIsActive($value)
{
    $this->is_active = $value;

    return $this;
}

public function gettIsActive()
{
    return $this->is_active;

    return $this;
}


/**
 * Set salt
 *
 * @param string $salt
 * @return User
 */
public function setSalt($salt)
{
    $this->salt = $salt;

    return $this;
}

/**
 * Get salt
 *
 * @return string 
 */
public function getSalt()
{
    return $this->salt;
}


/**
 * @inheritDoc
 */
public function eraseCredentials()
{
}


public function __construct()
{
parent::__construct();
    $this->isActive = true;
    $this->salt = md5(uniqid(null, true));
}


public function getRoles()
{
    switch ($this->getType())
    {
            case 0:
                    return array('ROLE_ADMIN');
                    break;
            case 1:
            case 2:
            case 3:
                    return array('ROLE_USER');
                    break;

    }


}

/**
 * @see \Serializable::serialize()
 */
public function serialize()
{
    return serialize(array(
                    $this->id,
    ));
}

/**
 * @see \Serializable::unserialize()
 */
public function unserialize($serialized)
{
    list (
                    $this->id,
    ) = unserialize($serialized);
}
/**
 * @var integer $first_login
 */
private $first_login;


/**
 * Get is_active
 *
 * @return boolean 
 */
public function getIsActive()
{
    return $this->is_active;
}

/**
 * Set first_login
 *
 * @param integer $firstLogin
 * @return User
 */
public function setFirstLogin($firstLogin)
{
    $this->first_login = $firstLogin;

    return $this;
}

/**
 * Get first_login
 *
 * @return integer 
 */
public function getFirstLogin()
{
    return $this->first_login;
}
/**
 * @var \Doctrine\Common\Collections\ArrayCollection
 */
private $userPoints;





/**
 * @var integer $privacy
 */
private $privacy;


/**
 * Set privacy
 *
 * @param integer $privacy
 * @return User
 */
public function setPrivacy($privacy)
{
    $this->privacy = $privacy;

    return $this;
}

/**
 * Get privacy
 *
 * @return integer 
 */
public function getPrivacy()
{
    return $this->privacy;
}
/**
 * @var integer
 */
private $enable;


/**
 * Set enable
 *
 * @param integer $enable
 * @return User
 */
public function setEnable($enable)
{
    $this->enable = $enable;

    return $this;
}

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

我的安全.yml

security:
firewalls:
    main:
        pattern: ^/
        form_login:
            provider: fos_userbundle
            login_path: /login
            use_forward: false
            check_path: /login_check
            csrf_provider: form.csrf_provider
        logout:       true
        anonymous:    true
providers:
    fos_userbundle:
        id: fos_user.user_provider.username

encoders:
    FOS\UserBundle\Model\UserInterface: sha512

role_hierarchy:
    ROLE_ADMIN:       ROLE_USER
    ROLE_SUPER_ADMIN: ROLE_ADMIN

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

5 回答 5

3

看来您的 FOSUserBundle 版本不好......我在 1.3.* 上遇到了同样的问题,我解决了这个问题,只是将其更改为版本“~2.0@dev”。

你可以查看你的“fos_user”表来检查这个;如果它只包含一个“id”字段,则您的用户实体没有扩展正确的“FOS\Entity\User”对象......尝试在“composer.json”中升级您所需的捆绑包版本,然后重建您的表(在完整的硬重建下 - 数据丢失):

php app/console doctrine:schema:drop --force
php app/console doctrine:schema:create

如果您的“fos_user”表包含所有必填字段,那么您很好。

于 2013-06-22T16:09:57.233 回答
2

查看有关创建使用类的文档:https ://github.com/FriendsOfSymfony/FOSUserBundle/blob/master/Resources/doc/index.md

您的 User 类不应重复基类中的所有属性(用户名等)。它应该只有新的属性,如名称和 ID。

虽然您没有显示您的学说映射文件,但我猜您可能复制的所有内容都很好?仅映射新属性。

于 2013-03-29T13:53:13.940 回答
1

事实上,我想,你应该在 config.yml 上有一些代码作为

fos_user:  
    db_driver: orm # other valid values are 'mongodb', 'couchdb' and 'propel'
    firewall_name: main  
    user_class: Acme\ProjectBundle\Entity\User

你应该不需要添加某事。FOSUser的orm设置。

于 2013-03-29T13:42:57.680 回答
0
orm:
    auto_generate_proxy_classes: "%kernel.debug%"
    #auto_mapping: true
    default_entity_manager: default
    entity_managers:
       default:            
          // that's for APCu or APC
          metadata_cache_driver: apc
          result_cache_driver: apc
          query_cache_driver: apc

在 dev env APC 中禁用,这就是您收到此错误的原因。您必须为 dev 评论它或启用 cacheClassLoader

于 2014-09-21T10:36:59.080 回答
0

我遇到了这个麻烦并应用了 PieroWbmstr 的建议,并开始使用 2.0 而不是 1.3.6 ...在 config.yml 中设置为 true 的教义.orm.auto_mapping

一旦我进行了 composer.json 版本切换和升级,我的学说:模式:更新立即识别出当前数据库实例中缺少的新字段,并应用它们。

FOS/UserBundle 中较新版本的用户类似乎没有任何显着的变化会迫使映射很好地发挥作用。有谁知道这两个版本有什么区别?或者更直接地说,为什么旧​​版本不让教义识别它是 xml 映射(提示:在我的两个 FOS/UserBundle 版本中,我将本地自定义捆绑包设置为使用注释)。

谢谢

于 2015-07-01T11:45:37.060 回答