laravel csrf验证总结

admin3年前PHP教程74

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验证内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

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

相关文章

editplus和notepad++哪个好用

editplus和notepad++哪个好用Editplus和Notepad++哪个好用?在程序员的日常工作中,修改器的运用是不行缺少的,一个好用便利的文本修改器会在必定程度上提高工作效率,Notep...

oracle数据库(oracle数据库是什么类型的数据库)

oracle数据库ORACLE数据库体系是美国ORACLE公司(甲骨文)供给的以分布式数据库为中心的一组软件产品,是最盛行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。比方...

php的配置文件是什么(php的框架有哪些)

php的配置文件是什么&lt;强&gt;php的装备文件是哪两个?php的装备文件一般是php。ini文件以及httpd.conf文件。php。ini文件必须命名为&#39;p...

提高海外多ip服务器速度的方法有哪些

提高海外多ip服务器速度的方法:1、选择直连网络的骨干点,减少在路由节点上所消耗的时间,提高服务器速度;2、选择采用大带宽的海外服务器,能提高服务器速度;3、采用BGP智能线路,能智能选择最优路线,保...

杭州高防服务器购买怎么选择

在购买杭州高防服务器时,您可以考虑以下几个方面进行选择:服务器性能和配置:根据您的实际需求,选择适合的服务器配置,例如处理器、内存、硬盘、带宽等。如果您需要处理大量数据或高并发访问,需要选择性能更高的...

PHP中=&gt;和-&gt;以及::符号的用法

没关系,下面我们做一下详细的解释,如果你有C++,Perl基础,你会发现这些家伙和他们里面的一些符号功能是差不多的。‘- >'符号插入式解引用操作符”(infix...