Laravel"该页面由于不活动而过期"

时间:2018-03-22 07:29:02

标签: laravel session csrf

错误

Enter image description here

我的情景

首先,我知道此错误消息是CSRF /会话错误消息,并且没有问题;事实上,它表现得像预期的那样。出于特定于我的申请的原因,我已将其设置为访问帐户,我发送帖子请求并根据该响应数据构建页面。

问题是当会话在该页面上超时时,我的应用程序什么都不做,但抛出此错误消息。然后我实际上必须输入一个URL才能重定向到登录页面,这对客户来说并不理想。

我的问题

如何控制应用程序的行为,以便我可以修改发生此CSRF错误时发生的情况,例如,如果我想创建自定义页面或使用控制器执行重定向等等?

不同之处在于我知道这个错误是什么。我想要一种在出现此错误时重定向的方法,我不是要阻止错误显示,而是我尝试从中重定向。就我而言,这不是一个错误;这是我期待的一种行为!

1 个答案:

答案 0 :(得分:7)

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.');

   }

行之前:

return parent::render($request, $e);

这应该重定向到令牌不匹配时登录。

链接进一步说明:https://gist.github.com/jrmadsen67/bd0f9ad0ef1ed6bb594e