laravel csrf验证总结

admin3年前PHP教程60

laravel csrf验证总结

前言问题:
laravel 在web路由下无论是表单提交啊 还是ajax请求啊 只要是请求方式不满足 ['HEAD', 'GET', 'OPTIONS']
就会报419错误,原因是其自带开启csrf验证,防止csrf攻击
感兴趣的可以看看这部分源码:Illuminate\Foundation\Http\Middleware\VerifyCsrfToken

解决方式:

一.屏蔽csrf验证

部分屏蔽
App\Http\Middleware\VerifyCsrfToken.php
protected $except = [
//这里添加屏蔽的路由地址
];

全部屏蔽
App\Http\Kernel.php
注释 \App\Http\Middleware\VerifyCsrfToken::class,

二.加入csrf验证参数

form提交


<input type="hidden" name="_token" value="{{csrf_token()}}">

ajax提交


<meta name="_token" content="{{csrf_token()}}">
$.ajax({
   url: "xxxx",
   type: "POST",
   data: data,
   headers: {
     'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content')
     },
   success: function (data) {}
  });

注意!!!

因为呢 laravel的token是存储在session里的,所以呢,我遇到了一个大坑,代码传到linux里后 csrf总报错???
最后debug发现 因为提交的token值与session里的不一致
(md 因为 storag2目录么权限 —>storage/framework/sessions 是存储session的目录)
开启777就ok了

最后总结一下排错顺序

1.检查表单有没有 csrf_token
2.linux 下storage有没有读写权限
3.检查session存储位置时候更换过(换过里面还是否有_token)
4.清除浏览器缓存,laravel缓存
最后没招 自己源码debug吧

到此这篇关于laravel csrf验证总结的文章就介绍到这了,更多相关laravel csrf验证内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

为什么很多企业选泰国服务器租用

为什么很多企业选泰国服务器租用?以下是一些企业选择泰国服务器租用的原因:更低的成本:相对于其他发达国家,泰国的劳动力和能源成本更低。这使得泰国成为了许多跨国公司和中小型企业选择机房托管和服务器租用服务...

阿里云服务器搭建Php+Apache运行环境的详细过程

1.apache1.1 安装apache使用yum命令安装 :yum -y install httpd执行结果如下:1.2 开启apache开启apache:systemctl start httpd...

泉州高防服务器价格受哪些因素影响

泉州高防服务器价格受以下几个因素影响:1.高防服务器的规格和配置。不同的高防服务器规格和配置不同,价格也会相应不同。一般来说,规格和配置越高,价格也越贵。2.租用时间长度。租用时间长度越长,价格通常会...

源码分析系列之json_encode()如何转化一个对象

目录初步测试JsonSerializable源码分析分析Demojson_encode()如何转化一个对象? 使用 json_encode() 将数组 array&nbs...

php遇到错误Call to undefined function ImageCreate()解决方法

目录常规Ubuntu与windows编译make安装方法phpize方法centos安装GD库在使用php处理一些图像时,有时会出现诸如这样的错误:Call to undefined function...

成都gpu服务器系统选择哪个好

GPU服务器系统是进行高性能计算任务和数据处理的重要工具。选择一个适合自己需求的GPU服务器系统,将会极大地提高计算效率和数据处理能力。然而,面对众多的GPU服务器系统,该如何选择呢?下面我们将从几个...