laravel 5.4 报错 TokenMismatchException in VerifyCsrfToken.php

♩. 报错情况

form 表单进行 post 方式提交数据时,遇到如下的报错情况
TokenMismatchException  in VerifyCsrfToken.php line 67:
in VerifyCsrfToken.php line 67
post æ°æ®æ交æ¥é

♪. 原因

  • 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
1
方法 ④
修改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 = [

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

protected $except = [

    'api/*'

];
举例: 

♬. 补充 csrf 介绍

csrf  图解释义

§ 参考文章

猜你喜欢

转载自blog.csdn.net/qq_40270754/article/details/85011544