Laravel Auth ::注销不删除记住我的cookie

时间:2015-05-26 18:40:38

标签: php session laravel cookies laravel-4

因此,我将会话的生命周期设置为两周,因此用户无需多次登录或注销。但是今天我注意到了一些事情,如果你注销它会破坏你的会话,但会在你的浏览器上记住我的cookie。这会导致问题,因为如果您在同一台计算机上切换足够的帐户8-10次,则会收到400错误的请求错误,因为您发送的信息过多。现在,在一个正常的生命周期中,有8到10倍的时间,但是当你的生命周期是两周时,我遇到了问题。

这是连续几次登录和退出时发生的事情的屏幕截图。 enter image description here如何在用户注销时删除生命周期cookie?到目前为止我已经尝试了

    Auth::logout();
    Session::flush();

1 个答案:

答案 0 :(得分:3)

似乎cookie不会自动解除设置。但是,您可以在注销后在控制器中返回重定向响应之前执行此操作。

public function getLogout() {
    // your code here
    .....
    // Get remember_me cookie name
    $rememberMeCookie = Auth::getRecallerName();
    // Tell Laravel to forget this cookie
    $cookie = Cookie::forget($rememberMeCookie);

    return Redirect::to('/')->withCookie($cookie);
}

请记住使用重定向重新启动cookie,否则无效。