微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Laravel 5.8 在提交 ajax POST 时显示 CSRF 令牌不匹配

如何解决Laravel 5.8 在提交 ajax POST 时显示 CSRF 令牌不匹配

  1. 我在标题视图中添加代码,如下所示
<head>
<Meta name="csrf-token" content="{{ csrf_token() }}">
</head>
  1. 我的ajax代码如下
$.ajaxSetup({
          headers:
          {
            'X-CSRF-TOKEN': $('Meta[name="csrf-token"]').attr('content')
          }
 });
 $.ajax({
          method: "POST",url: "{{ route('ProgresOps.store') }}",data: form_data,contentType: false,// The content type used when sending data to the server.
          cache: false,// To unable request pages to be cached
          processData: false,})
        .done(function(data){
          toastr.success('Data saved.');
});

但是当我提交数据时结果是csrf不匹配,我还没有找到解决方

exception: "Symfony\Component\HttpKernel\Exception\HttpException"
file: "C:\xampp74new\htdocs\swms\vendor\laravel\framework\src\Illuminate\Foundation\Exceptions\Handler.PHP"
line: 208
message: "CSRF token mismatch."

解决方法

有很多方法干脆试试这个(直接发送带有数据的csrf token)

data: {
        "_token": "{{ csrf_token() }}",}
,

有两种可能:

  1. 来自 Ajax 的请求不匹配 CSRF 令牌参数,通过将 CSRF 令牌参数添加到您的请求中来解决它 $.extend( query,{ '_token' : 'your csrf token' });

  2. cookie 中的 XSRF-TOKEN 不匹配。就我而言,我已通过更改 config\session.php 中的配置解决了该问题 将安全配置从 true 更改为 false

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。