Sie können dem Ereignis security.interactive_login
einen Listener hinzufügen.
befestigen Sie Ihren Hörer wie so. In diesem Beispiel gebe ich auch den Sicherheitskontext und die Sitzung als Abhängigkeiten weiter.
Hinweis: Security als von Symfony 2.6 veraltet. Bitte beachten Sie http://symfony.com/blog/new-in-symfony-2-6-security-component-improvements
parameters:
# ...
account.security_listener.class: Company\AccountBundle\Listener\SecurityListener
services:
# ...
account.security_listener:
class: %account.security_listener.class%
arguments: ['@security.context', '@session']
tags:
- { name: kernel.event_listener, event: security.interactive_login, method: onSecurityInteractiveLogin }
und in Ihrem Hörer können Sie speichern, was Sie auf der Sitzung wollen. In diesem Fall stelle ich die Zeitzone des Benutzers ein.
<?php
namespace Company\AccountBundle\Listener;
use Symfony\Component\Security\Core\SecurityContextInterface;
use Symfony\Component\HttpFoundation\Session\Session;
use Symfony\Component\Security\Http\Event\InteractiveLoginEvent;
class SecurityListener
{
public function __construct(SecurityContextInterface $security, Session $session)
{
$this->security = $security;
$this->session = $session;
}
public function onSecurityInteractiveLogin(InteractiveLoginEvent $event)
{
$timezone = $this->security->getToken()->getUser()->getTimezone();
if (empty($timezone)) {
$timezone = 'UTC';
}
$this->session->set('timezone', $timezone);
}
}
Wie es mit einem Dienst zu tun: http://stackoverflow.com/questions/8308050/how-to-disable-redirection-after-login-check-in-symfony-2/8312188#8312188 – unairoldan