Laravel“页面由于不活动而过期”

问题描述 投票:6回答:1

错误

Enter image description here

我的场景

首先,我知道此错误消息是CSRF /会话错误消息,这很好;实际上,它的行为符合预期。由于特定于我的应用程序的原因,我这样做是为了访问一个帐户,我发送了一个发布请求,并根据该响应数据构建了页面。

问题是,当该会话在该页面上超时时,我的应用程序不执行任何操作,但会抛出此错误消息。然后,我必须物理上输入URL才能重定向到对客户端不理想的登录页面。

我的问题

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

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

laravel session csrf
1个回答
9
投票

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

© www.soinside.com 2019 - 2024. All rights reserved.