如果在Symfony2中帐户未完成,则在首次登录后重定向到配置文件编辑页面


Redirecting to profile edit page after first login if account isn't complete in Symfony2

对于我的帐户和日志的东西,我使用FOSUserBundle,它符合我的所有要求。

我已经创建了注册表格,只有很少的输入(用户名,电子邮件和密码),不吓唬访问者长注册表格。然而,对于使用新创建的帐户,客户端需要提供有关他的公司,地址等信息,所以在第一次登录后,我想重定向我的客户端到帐户编辑页面,在那里他或她可以填写所有所需的输入,但不允许访问其他帐户页面,而配置文件不完整。

我已经找到了一个很好的例子,如何在登录后重定向客户端,但这将在每次客户端登录时工作,我打赌只有在客户端配置文件不完整的情况下才需要这样做。

登录后重定向用户的代码:

firewalls:
    secured_area:
        form_login:
            always_use_default_target_path: true
            default_target_path: /loggedinpage

前段时间我有一个相当类似的需求。我的解决方案是使用一个请求侦听器,它检查一些先决条件并适当地重定向。


src/Acme/HelloBundle/EventListener UserRedirectListener.php

<?php
namespace Acme'HelloBundle'EventListener;
use Symfony'Component'HttpFoundation'RedirectResponse;
use Symfony'Component'HttpKernel'Event'GetResponseEvent;
use Symfony'Component'HttpFoundation'Response;
use Symfony'Component'HttpKernel'HttpKernel;
use Symfony'Component'Security'Core'SecurityContext;
use Symfony'Bundle'FrameworkBundle'Routing'Router;
use Symfony'Component'Validator'Validator'ValidatorInterface;
use Acme'UserBundle'Entity'User;
class UserRedirectListener
{
  /**
   * @var SecurityContext
   */
  private $securityContext;
  /**
   * @var Router $router
   */
  private $router;
  /**
   * @var ValidatorInterface $validator
   */
  private $validator;
  /**
   * @param SecurityContext    $securityContext
   * @param Router             $router
   * @param RecursiveValidator $validator
   */
  public function __construct(SecurityContext $securityContext, Router $router, ValidatorInterface $validator) {
    $this->securityContext = $securityContext;
    $this->router          = $router;
    $this->validator       = $validator;
  }
  /**
   * @param GetResponseEvent $event
   */
  public function onKernelRequest(GetResponseEvent $event) {
    if (HttpKernel::MASTER_REQUEST !== $event->getRequestType()) {
      // don't do anything if it's not the master request
      return;
    }
    // get the user
    $user = $this->securityContext->getToken()->getUser();
    if (!$user instanceof User) {
      return;
    }
    // validate
    $errors = $this->validator->validate($user, null, array('email'));
    if (count($errors) === 0) {
      return;
    }
    // get current route
    $route = $event->getRequest()->attributes->get('_route');
    // filter allowed routes
    switch ($route) {
      case 'some_route':
      case 'some_other_route':
        return;
    }
    // redirect
    $event->setResponse(new RedirectResponse($this->router->generate('target_route')));
  }
}

service . xml

<service id="user_redirect_listener" class="%user_redirect_listener.class%">
  <argument type="service" id="security.context" />
  <argument type="service" id="router" />
  <argument type="service" id="validator" />
  <tag name="kernel.event_listener" event="kernel.request" method="onKernelRequest" />
</service>

validation.yml

Acme'UserBundle'Entity'User:
    properties:
        email_activated:
           - 'True': { groups: [email] }