6

我将 Zend Framework 2 与 ZfcUser、BjyAuthorize 和 Doctrine 一起用于数据库。到目前为止,注册等工作得很好。我的问题是,注册用户没有分配角色,所以我想在注册过程中为用户添加角色“用户”。

我想我可以将它附加到“注册”事件中,但我不知道该怎么做。

我希望有一个人可以帮助我 ...

(我使用本教程设置 zfcuser 等http://samminds.com/2013/03/zfcuser-bjyauthorize-and-doctrine-working-together/

public function onBootstrap(MvcEvent $e)
{
    $zfcServiceEvents = $e->getApplication()->getServiceManager()->get('zfcuser_user_service')->getEventManager();
    $zfcServiceEvents->attach('register', function($e) {
        $user = $e->getParam('user');
        // probably the role must be added here, with $user->addRole();
        // but how do i get the user Role Entity to add from DB?

});
4

4 回答 4

7

基于 DangelZM 的回答,并使用关于事件管理器的另一个参考(请参阅我的帖子末尾的链接),我想出了这个解决方案,它将潜在的 ZfcUser 事件侦听器组织到一个用户侦听器对象中。

注意:我创建了自己的名为 NvUser 的用户模块,因此根据您的模块名称,您必须将 NvUser 的所有引用替换为您的用户模块名称。

概括

我创建了一个 NvUserListener 对象,它本身可以将事件侦听器附加到共享事件管理器,并容纳事件侦听器回调。

在 NvUser/Module.php 内部:

<?php
namespace NvUser;

use Zend\Mvc\MvcEvent;
use NvUser\Listener\NvUserListener;

class Module
{
    public function onBootstrap(MvcEvent $mvcEvent)
    {
        $em = $mvcEvent->getApplication()->getEventManager();
        $em->attach(new NvUserListener());
    }               
}

在 NvUser/src/NvUser/Listener/NvUserListener.php 里面:

<?php
namespace NvUser\Listener;

use Zend\EventManager\AbstractListenerAggregate;
use Zend\EventManager\EventManagerInterface;
use Zend\EventManager\Event;

class NvUserListener extends AbstractListenerAggregate
{
    public function attach(EventManagerInterface $events)
    {
        $sharedManager = $events->getSharedManager();
        $this->listeners[] = $sharedManager->attach('ZfcUser\Service\User', 'register', array($this, 'onRegister'));
        $this->listeners[] = $sharedManager->attach('ZfcUser\Service\User', 'register.post', array($this, 'onRegisterPost'));
    }

    public function onRegister(Event $e)
    {
        $sm = $e->getTarget()->getServiceManager();
        $em = $sm->get('doctrine.entitymanager.orm_default');
        $user = $e->getParam('user');
        $config = $sm->get('config');
        $criteria = array('roleId' => $config['zfcuser']['new_user_default_role']);
        $defaultUserRole = $em->getRepository('NvUser\Entity\Role')->findOneBy($criteria);

        if ($defaultUserRole !== null)
        {
            $user->addRole($defaultUserRole);
        }
    }

    public function onRegisterPost(Event $e)
    {
        $user = $e->getParam('user');
        $form = $e->getParam('form');

        // Do something after user has registered
    }
}

在 NvUser/config/module.config.php 中:

<?php
namespace NvUser;

return array(
    'zfcuser' => array(
        'new_user_default_role' => 'user',
    ),
);

参考:

了解 Zend Framework 2 事件管理器

于 2014-08-22T03:28:39.697 回答
5

也许这不是最好的解决方案,但它对我有用。在配置范围内添加 user_role_id 选项。

    public function onBootstrap(MvcEvent $mvcEvent)
    {
        $zfcServiceEvents = $mvcEvent->getApplication()->getServiceManager()->get('zfcuser_user_service')->getEventManager();
        $zfcServiceEvents->attach('register', function($e) use($mvcEvent) {
            $user = $e->getParam('user');
            $em = $mvcEvent->getApplication()->getServiceManager()->get('doctrine.entitymanager.orm_default');
            $config = $mvcEvent->getApplication()->getServiceManager()->get('config');
            $defaultUserRole = $em->getRepository('SamUser\Entity\Role')->find($config['user_role_id']);
            $user->addRole($defaultUserRole);
        });
    }

也许有人会提供更好的解决方案。

于 2013-08-25T21:51:32.480 回答
1

这工作也是。

  public function onBootstrap(MvcEvent $mvcEvent)
     {
         $zfcServiceEvents = $mvcEvent->getApplication()-getServiceManager()->get('zfcuser_user_service')->getEventManager();
         $zfcServiceEvents->attach('register', function($e) use($mvcEvent) {
             $user = $e->getParam('user');
             $em = $mvcEvent->getApplication()->getServiceManager()-get('doctrine.entitymanager.orm_default');
             $defaultUserRole = $em->getRepository('SamUser\Entity\Role')-find('id_of_your_role_on_table_role_for_example: '2'');
             $user->addRole($defaultUserRole);
         });
     }
于 2015-10-23T19:53:30.810 回答
0

我刚刚使用了一个 MySQL 触发器

DROP TRIGGER IF EXISTS `user_role_after_insert_trig`;
DELIMITER //
CREATE TRIGGER `user_role_after_insert_trig` AFTER INSERT ON `user`
 FOR EACH ROW begin
  insert into user_role_linker (user_id,role_id) values (new.user_id, 5);
end
//
DELIMITER ;
于 2013-09-04T15:53:46.417 回答