0

我正在尝试从 security.yml 中手动指定的用户转移到数据库用户。我已阅读http://symfony.com/doc/current/book/security.html#loading-users-from-the-database并实现了他们的示例,然后使用朋友的用户类对其进行了扩展。当我尝试运行时,php app/console doctrine:generate:entities我收到以下错误:Class MyFreelancer\PortalBundle\Entity\User contains 7 abstract methods and must therefor be declared abstract or implement the remaining methods然后是离开页面的方法列表。

我的代码如下:

<?php
namespace MyFreelancer\PortalBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\Criteria;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
use Symfony\Component\Validator\Constraints as Assert;
use JMS\Serializer\Annotation as Ser;
use Gedmo\Mapping\Annotation as Gedmo;

use Symfony\Component\Security\Core\User\Role;
use Symfony\Component\Security\Core\User\UserInterface;

/**
 * User
 *
 * @ORM\Entity
 * @ORM\Table(name="users")
 * @Ser\ExclusionPolicy("all")
 */
class User implements UserInterface, \Serializable
{
    /**
     * @var integer
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     * @Ser\Expose
     */
    private $id;

/**
     * @var string
     *
     * @ORM\Column(name="role_id", type="integer")
     * @Assert\Range(min=1)
     */
    private $roleId;

    /**
     * @var string
     *
     * @ORM\Column(name="username", type="string", length=100)
     * @Assert\Length(min=3, max=100)
     * @Ser\Expose()
     */
    private $username;

    /**
     * @var string
     *
     * @ORM\Column(name="password", type="string", length=2048)
     * @Assert\Length(min=8, max=2048)
     */
    private $password;

    /**
     * @var string
     *
     * @ORM\Column(name="name", type="string", length=100)
     * @Assert\Length(min=3, max=100)
     * @Ser\Expose()
     */
    private $name;

    /**
     * @var string
     *
     * @ORM\Column(name="surname", type="string", length=100)
     * @Assert\Length(min=3, max=100)
     * @Ser\Expose()
     */
    private $surname;

    /**
     * @var string
     *
     * @ORM\Column(name="email", type="string", length=200)
     * @Assert\Email(checkMX=true)
     * @Ser\Expose()
     */
    private $email;

    /**
     * @var string
     *
     * @ORM\Column(name="cell", type="string", length=20, nullable=true)
     * @Assert\Length(min=10, max=20)
     * @Ser\Expose()
     */
    private $cell;

}
?>

我查看了 Users Entity Provider 中的 Symfony2 致命错误,但如果我必须手动实现它们,我不知道这些方法必须包含什么内容。另外, doctine:generate:entities 不应该为你做这件事吗?如果将类声明为抽象类更容易,我该怎么做?这意味着什么?

当我们讨论这个话题时,我如何将保存用户角色保存/检索到数据库,例如(来自 security.yml)

role_hierarchy:
    ROLE_ADMIN:       ROLE_USER
    ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

这实际上是第二个问题,如果在这里无法回答,那么我将打开一个新主题。感谢所有阅读此问题的人。

4

1 回答 1

1

http://symfony.com/doc/current/cookbook/security/entity_provider.html上有关实体提供者的食谱文章显示了如何正确设置它。

于 2013-10-30T20:07:43.110 回答