Doctrine 不映射来自 FOSUserBundle 和 FOSOAuthServerBundle 的字段

Doctrine doesn't map fields from FOSUserBundle and FOSOAuthServerBundle

我正在使用 Symfony 2.8、FOSUserBundle 1.3 和 FOSOAuthServerBundle 1.5

对于这些捆绑包工作所需的所有 class,我最终以学说未正确更新我的模式而告终。我的意思是它没有考虑 Base Class.

中的字段
CREATE TABLE oauh2_access_tokens (id INT NOT NULL, client_id INT NOT NULL, user_
id INT DEFAULT NULL, PRIMARY KEY(id));
    CREATE TABLE oauth2_auth_codes (id INT NOT NULL, client_id INT NOT NULL, user_id
 INT DEFAULT NULL, PRIMARY KEY(id));
CREATE TABLE oauth2_clients (id INT NOT NULL, PRIMARY KEY(id));
CREATE TABLE oauth2_refresh_tokens (id INT NOT NULL, client_id INT NOT NULL, use
r_id INT DEFAULT NULL, PRIMARY KEY(id));

这是我的配置:

doctrine:
    orm:
        #auto_generate_proxy_classes: "%kernel.debug%"
        default_entity_manager: default
        entity_managers:
            default:
                connection: default
                naming_strategy: doctrine.orm.naming_strategy.underscore
                mappings:
                    COMPANYAuthBundle: ~

fos_user:
    db_driver: orm
    firewall_name: api
    user_class: COMPANY\AuthBundle\Entity\User

#FOSOAuthBundle Configuration
fos_oauth_server:
    db_driver: orm
    client_class: COMPANY\AuthBundle\Entity\Client
    access_token_class: COMPANY\AuthBundle\Entity\AccessToken
    refresh_token_class: COMPANY\AuthBundle\Entity\RefreshToken
    auth_code_class: COMPANY\AuthBundle\Entity\AuthCode
    service:
        user_provider: fos_user.user_manager

这是我的 class 用户

<?php

namespace COMPANY\AuthBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use FOS\UserBundle\Entity\User as BaseUser;

/**
 * Utilisateur
 *
 * @ORM\Table(name="users")
 * @ORM\Entity
 */
class User extends BaseUser
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    public function __construct()
    {
        parent::__construct();
        // your own logic
    }

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

所以,是的,我确实正确使用了而不是 FOS\UserBundle\Model\User 作为 BaseUser;

OAuthServerBundle 的 class 也一样:(我只是在这里放一个,它们都遵循相同的模式)

<?php

namespace COMPANY\AuthBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use FOS\OAuthServerBundle\Entity\Client as BaseClient;

/**
 * Client
 *
 * @ORM\Table(name="oauth2_clients")
 * @ORM\Entity(repositoryClass="COMPANY\AuthBundle\Repository\ClientRepository")
 */
class Client extends BaseClient
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;


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

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

有人知道为什么 class 基础字段没有放入我的数据库吗?谢谢:)

好的,经过10个小时的搜索,我找到了解决方案...

解决方案是不要忘记将 FOSUserBundle 和 FOSOAuthServerBundle 以及所有基础 class 捆绑包添加到您的映射中......

所以这应该是配置:

doctrine:
orm:
    #auto_generate_proxy_classes: "%kernel.debug%"
    default_entity_manager: default
    entity_managers:
        default:
            connection: default
            naming_strategy: doctrine.orm.naming_strategy.underscore
            mappings:
                COMPANYAuthBundle: ~
                FOSUserBundle: ~
                FOSOAuthBundle: ~

此外,如果您想使用每个包的路由,则不能使一个包继承两个包。因此,为每个创建一个包。然后在每个Bundleclass中添加如下函数:

public function getParent()
{
    return "FOSOAuthServerBundle";  //Or return "FOSUserBundle"; but you can't put both
}