php – 启用“记住我”时,在Symfony 2应用程序中注销用户

我正在寻找一种方法来记录用户退出Symfony 2应用程序,但无法找到正确的方法.

我试过这里描述的方法
Symfony2: how to log user out manually in controller?

$this->get('security.context')->setToken(null);
$this->get('request')->getSession()->invalidate();

当“remember me”被禁用时,它工作正常,但是,当我启用它时,它不起作用.看起来这个cookie会再次自动重新验证用户.

remember_me:
    key:      "%secret%"
    lifetime: 31536000
    path:     /
    domain:   ~
    always_remember_me: true

用户退出Symfony 2应用程序的正确方法是什么?我是否需要从服务器端另外删除此cookie?

您可能必须显式调用session-storage的save()( Documentation)方法.

Force the session to be saved and closed.

此外,您可以通过响应标头请求删除session-和/或remember_me-cookies.

session-cookie的名称配置为容器参数framework.session.name,认为PHP.ini中的session.name值.

$cookieName = $this->container->getParameter('framework.session.name');
$response->headers->clearCookie( $cookieName );

可以在安全配置中配置remember_me-cookie的名称.

security:
    firewalls:
        your_firewall:
            remember_me: 
                name: neverforget # <- cookie-name

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...