我試圖強迫用戶時已經過期的會話成爲註銷,但我不能訪問會話的時間在這裏會話過期時,如何強制用戶註銷?
namespace mio\mioBundle;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpKernel\HttpKernelInterface;
use Symfony\Component\HttpKernel\Event\GetResponseEvent;
use Symfony\Bundle\FrameworkBundle\Routing\Router;
use Symfony\Component\Routing\RouterInterface;
use Symfony\Component\Security\Core\SecurityContext;
use Symfony\Component\HttpFoundation\Request;
class RequestListener{
protected $router;
protected $security;
public function __construct(RouterInterface $router, SecurityContext $security)
{
$this->router = $router;
$this->security = $security;
}
public function onKernelRequest(GetResponseEvent $event)
{
echo $event->getRequest()->getSession()->('timeout');
}
}
你好我離開配置文件security.yml。
security:
firewalls:
frontend:
pattern: ^/
anonymous: ~
form_login:
login_path: /login
check_path: /login_check
default_target_path: /index
success_handler: authentication_handler
logout:
path: /logout
target: /login
success_handler: authentication_handler
security: true
remember_me:
key: loksea
lifetime: 1800
path: /
access_denied_handler: accessdenied_handler
#primero deben de ir los usuarios anonimos si no se entra en loop redirect
access_control:
- { path: /login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/pruebita, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/js, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/admin, roles: ROLE_A }
- { path: ^/nuevoinforme, roles: ROLE_M }
- { path: ^/, roles: IS_AUTHENTICATED_REMEMBERED }
providers:
user_db:
entity: { class: mio\mioBundle\Entity\Empleado, property: username }
role_hierarchy:
ROLE_M: ROLE_U
ROLE_A: ROLE_U
encoders:
mio\mioBundle\Entity\Empleado: { algorithm: sha1 }
Symfony\Component\Security\Core\User\User: plaintext
當會話結束後要求我再次登錄,但不是用戶註銷。我有一個聽衆保存退出如此:
public function onLogoutSuccess(Request $request){
$empleado = $this->security->getToken()->getUser();
$log = new Log();
$log->setFechalog(new \DateTime('now'));
$log->setTipo("Salida");
$log->setEmpleado($empleado);
$this->em->persist($log);
$this->em->flush();
}
會話結束時你會調用這個方法嗎?謝謝。
這可能是一個[重複問題](http://stackoverflow.com/questions/15504525/symfony2-login-remember-me)。 – 2013-03-20 05:36:09
@ThomasPotaire我會完全考慮他們的不同問題,儘管他們可能會共享相同的解決方案。 – 2013-03-21 01:15:13