我遇到了问题,早期我的实体只扮演一个角色,这足以满足项目需求。但是现在我的实体需要扮演ROLE_DEVELOPER,ROLE_COMPANY之类的角色,并且当用户对实体进行某些操作时会添加新角色。在这种情况下,如何最好地创建新实体或更改数组中的字段角色呢?
我在表用户中有实体,并且有一个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
参考方案
首先,您可以使用hierarchical roles,因此可以将类似的内容添加到您的配置中:
# 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。
然后,您可以在“角色”和“用户”之间创建多对多引用。
如果您有任何疑问,请告诉我。
PHP:获取调用引用的数组名称 - php假定以下函数并调用:function doSomething( &$someArray ) { // Do something to $someArray } $names=array("John", "Paul", "George", "Ringo"); doSomet…
PHP-MySQL结果转换为JSON - php我试图了解如何将MySQL结果转换为JSON格式,以便以后可以在Javascript中使用此JSON来构建HTML表。但是我的代码只是产生大量的空值,我还不明白为什么。$result = mysqli_query($con, "SELECT * FROM Customers"); $test = json_encode($result);…
PHP Count数组元素 - php嗨,有人可以解释为什么这会返回“数组由0个元素组成”。 :$arr = array(1,3,5); $count = count($arr); if ($count = 0) { echo "An array is empty."; } else { echo "An array has $count elements.…
PHP:从函数返回值并直接回显它? - php这可能是一个愚蠢的问题,但是……的PHPfunction get_info() { $something = "test"; return $something; } html<div class="test"><?php echo get_info(); ?></div> 有没有办…
PHP:将数据从二维数组复制到一维数组的最快方法 - php我有一个巨大的二维PHP数组,带有500万行。$t = [ [ "id" => 1, "name" => "foo" ], [ "id" => 2, "name" => "bar" ] ]; 现在,我必须将此数组的I…