Ken*_*ius 6 session csrf laravel
错误
我的情景
首先我知道这个错误消息是一个CSRF /会话错误消息,这很好; 实际上它表现得像预期的那样.由于特定于我的应用程序的原因,我已经这样做,以便访问帐户我发送一个帖子请求并根据该响应数据构建页面.
问题是,当会话在该页面上超时时,我的应用程序什么都不做,但抛出此错误消息.然后我实际上必须输入一个URL才能重定向到登录页面,这对客户来说并不理想.
我的问题
如何控制应用程序的行为,以便我可以修改发生此CSRF错误时发生的情况,例如,如果我想创建自定义页面或使用控制器执行重定向等?
不同之处在于我知道这个错误是什么.我想要一种方法来重定向此错误,我不是试图阻止显示错误,我正在尝试从它重定向.在我的情况下,这不是一个错误; 这是我期待的一种行为!
在你app/Exceptions/Handler.php的render函数中添加以下行:
if ($e instanceof \Illuminate\Session\TokenMismatchException) {
return redirect('/login')->with('message', 'Sorry, your session seems to have expired. Please login again.');
}
Run Code Online (Sandbox Code Playgroud)
在行之前:
return parent::render($request, $e);
Run Code Online (Sandbox Code Playgroud)
这应该重定向到令牌不匹配登录.
链接进一步说明:https://gist.github.com/jrmadsen67/bd0f9ad0ef1ed6bb594e