[英]Laravel Auth::logout not removing remember me cookie
因此,我将会话的生命周期设置为两周,这样用户就不必多次登录或注销。 但是今天我注意到了一些事情,如果您注销它会破坏您的会话,但会在您的浏览器上保留记住我的 cookie。 这会导致问题,因为如果您在同一台计算机上切换帐户 8-10 次,您会收到 400 bad request 错误,因为您发送的信息太多。 现在 8-10 次在一个 cookie 的正常生命周期中有点牵强,但是当你的生命周期是两周时,我遇到了问题。
这是登录和退出几次背靠背时发生的情况的屏幕截图。 用户注销时如何删除生命周期 cookie? 到目前为止我已经尝试过
Auth::logout();
Session::flush();
似乎 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,否则它将不起作用。
就我而言,我需要传递所有参数,而不仅仅是名称。
\Cookie::queue(\Cookie::forget('cookieName',null,'.yourdomain.com'));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.