Laravel VerifyCsrfToken 报错解决

12 篇文章 1 订阅

♩. 报错情况

  • form 表单进行 post 方式提交数据时,遇到如下的报错情况
TokenMismatchException  in VerifyCsrfToken.php line 67:
in VerifyCsrfToken.php line 67
at VerifyCsrfToken->handle(object(Request), object(Closure))

post 数据提交报错

  • 如果配置并开启了Debugbar,可能会得到如下的报错信息
...
return $this->addCookieToResponse($request,$next($request));
}
throw new TokenMismatchException;

♪. 原因

  • Laravel 推荐在全局注册 VerifyCsrfToken 的 Middleware ,对所有 Post、Put、Delete 请求自动校验是否带合法的 _csrf token

♫. 解决方法

方法 ①

  • 在form表单中添加如下的隐藏域代码
<input type="hidden" name="_token" value="{{ csrf_token() }}" />

方法 ②

  • 在form表单中添加 csrf_field (与上述解决方法功能一致)
{!! csrf_field() !!}

方法 ③

  • 注释 Kernel.php 代码
    打开 app\Http\Kernel.php,在文件中注释掉下面的代码
\App\Http\Middleware\VerifyCsrfToken::class

方法 ④

  • 修改handle()方法
    打开 \app\Http\Middleware\VerifyCsrfToken.php,添加或修改 handle()方法如下:
 public function handle($request, \Closure $next)
    {
        // 使用CSRF
        //return parent::handle($request, $next);
        // 禁用CSRF
        return $next($request);
    }

方法 ⑤

  • [适用于 Laravel5.5,取消请求的 csrf_token验证,不是取消全部]
  • 跟上述的方法4 类似,打开 app\Http\Middleware\VerifyCsrfToken.php 文件,找到
protected $except = [

];

例如我要 http://xx.com/api/ 下面的都跳过验证,可改成如下所示:

protected $except = [

    'api/*'

];

举例:

♬. 补充 csrf 介绍

csrf  图解释义

§ 参考文章

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值