微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

原文地址:https://www.jb51.cc/php/133754.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐