由于Sonata用户捆绑包和FOS用户捆绑包,我配置了用户管理。我创建了一些具有权限的组,并将用户放入其中。但当我登录这些用户配置文件时,我没有影响组的角色。
有人对此有解释吗?
FOS为使用addRole和setRoles中的序列化和非序列化数组的角色使用两个函数。您可以使用用户管理器api或条令实体管理器,也就是说,在控制器中创建如下操作:
public function registerUserAction(Request $request)
{
$task = new User();
$form = $this->createFormBuilder($task)
->add('username', 'text')
->add('email', 'email')
->add('enabled', 'choice', array(
'choices' => array('Enable' => 1, 'Disable' => 0),
'required' => true,
))
->add('password', 'password')
->add('roles')
->add('save', 'submit')
->getForm();
$form->handleRequest($request);
if($form->isValid()){
$username = $form->get('username')->getData();
$email = $form->get('email')->getData();
$pass = $form->get('password')->getData();
$enabled = $form->get('enabled')->getData();
$roles = $form->get('roles')->getData();
$task->setUsername($username);
$task->setEmail($email);
$task->setPlainPassword($pass);
$task->setRoles($roles);
$task->setEnabled($enabled);
$em = $this->getDoctrine()->getManager();
$em->persist($user);
$em->flush();
}
return $this->render('SafUserBundle:ManageUser:registerUser.html.twig', array(
'form' => $form->createView(),
));
}
确保在控制器顶部为http请求启用库,如下所示:
使用Symfony\Component\HttpFoundation\Request;
以上将在使用表单时粘贴模板和控制器。
在trick中,您可以一次输出表单{{form(form)}},如果您希望完全控制渲染,也可以逐字段写入。
User类中的roles属性是一个数组,因此在addRole 中使用类型转换
或者,您可以使用fosuserbundle 提供的用户管理器