[英]Symfony many role for user
我有問題,早期我的實體只有一個角色,這對於項目來說已經足夠了。 但是現在我的實體需要有很多角色,比如 ROLE_DEVELOPER、ROLE_COMPANY,當用戶對實體進行一些操作時添加新角色。 對於這種情況,如何最好地創建新實體或更改數組中的字段角色或什么? 我在表 user 中有實體並且有一個 ROLE_USER,現在用戶想要創建團隊,團隊需要角色 ROLE_TEAM,以及如何設置新角色? 然后用戶想要創建客戶端實體,我需要設置 ROLE_CLIENT。 如果我創建 ManyToMany 關系如何我的用戶,誰有很多角色認證? 在我想要創建的用戶個人資料中,如果用戶有 ROLE_TEAM - 用於轉到個人資料團隊的可見按鈕,但他的角色很多,我需要 foreach 數組角色嗎?
/**
* Users
*
* @ORM\Table(name="users")
* @ORM\Entity(repositoryClass="Artel\ProfileBundle\Entity\UsersRepository")
* @ExclusionPolicy("all")
*/
class Users implements UserInterface
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @Expose()
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @Gedmo\Slug(fields={"firstName", "lastName"}, separator="-", updatable=true)
* @ORM\Column(name="name", type="string", options={"default": "Company"}, length=255, nullable=false)
* @Assert\Length(min=3, max=255)
*/
protected $username;
/**
* @var string
*
* @ORM\Column(name="password", type="string", length=80, nullable=true)
*/
protected $password;
/**
* @ORM\ManyToMany(targetEntity="Role")
* @ORM\JoinTable(name="user_role",
* joinColumns={@ORM\JoinColumn(name="user_id", referencedColumnName="id")},
* inverseJoinColumns={@ORM\JoinColumn(name="role_id", referencedColumnName="id")}
* )
*
* @var ArrayCollection $userRoles
*/
protected $userRoles;
/**
* Constructor
*/
public function __construct()
{
$this->userRoles = new ArrayCollection();
}
/**
* Get salt
*
* @return string
*/
public function getSalt()
{
return '';
}
/**
* @inheritDoc
*/
public function eraseCredentials() { }
/**
* Геттер для ролей пользователя.
*
* @return ArrayCollection A Doctrine ArrayCollection
*/
public function getUserRoles()
{
return $this->userRoles;
}
/**
* Геттер для массива ролей.
*
* @return array An array of Role objects
*/
public function getRoles()
{
return $this->getUserRoles()->toArray();
}
}
實體角色
/**
* @ORM\Entity
* @ORM\Table(name="role")
*/
class Role implements RoleInterface
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*
* @var integer $id
*/
protected $id;
/**
* @ORM\Column(type="string", length=255)
*
* @var string $name
*/
protected $name;
/**
* @ORM\Column(type="datetime", name="created_at")
*
* @var DateTime $createdAt
*/
protected $createdAt;
/**
* Геттер для id.
*
* @return integer The id.
*/
public function getId()
{
return $this->id;
}
/**
* Геттер для названия роли.
*
* @return string The name.
*/
public function getName()
{
return $this->name;
}
/**
* Сеттер для названия роли.
*
* @param string $value The name.
*/
public function setName($value)
{
$this->name = $value;
}
/**
* Геттер для даты создания роли.
*
* @return DateTime A DateTime object.
*/
public function getCreatedAt()
{
return $this->createdAt;
}
/**
* Конструктор класса
*/
public function __construct()
{
$this->createdAt = new \DateTime();
}
/**
* Реализация метода, требуемого интерфейсом RoleInterface.
*
* @return string The role.
*/
public function getRole()
{
return $this->getName();
}
}
現在我裝箱夾具但有錯誤:
Artel\ProfileBundle\Entity\Role:
role0:
name: 'ROLE_FREELANCER'
role1:
name: 'ROLE_COMPANY'
role2:
name: 'ROLE_DEVELOPER'
Artel\ProfileBundle\Entity\Users:
users0:
........
userRoles: @role0
users{1..100}:
.......
userRoles: 2x @role*
[Symfony\Component\Debug\Exception\ContextErrorException]
Catchable Fatal Error: Argument 1 passed to Doctrine\Common\Collections \ArrayCollection::__construct() must be of the type array, object given, called in /var/www/aog-code/vendor/doctrine/orm/lib/Doctrine/ORM/UnitOfWork.php on line 605 and defined
首先,您可以使用分層角色 ,因此可以在配置中添加以下內容:
# app/config/security.yml
security:
# ...
role_hierarchy:
ROLE_DEVELOPER: ROLE_USER
ROLE_COMPANY: [ROLE_ADMIN, ROLE_DEVELOPER]
這意味着,如果您的用戶具有ROLE_COMPANY ,那么他還將具有ROLE_ADMIN , ROLE_DEVELOPER和ROLE_USER (因為ROLE_DEVELOPER具有ROLE_USER )
如果希望為每個用戶擁有單獨的角色,則可以創建Role實體 ,該實體應實現Symfony \\ Component \\ Security \\ Core \\ Role \\ RoleInterface 。
然后,您可以在Role和User之間創建多對多引用。
如果您有任何疑問,請告訴我。
可以通過這種方式在表用戶字段角色中保存許多角色: {"roles": ["ROLE_USER", "ROLE_ADMIN"]}
(json 格式)並更新用戶實體中的getRoles()
方法:
public function getRoles(): array
{
$roles = $this->roles["roles"];
// guarantee every user at least has ROLE_USER
return array_unique($roles);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.