laravel csrf验证总结

admin3年前PHP教程43

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

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

相关文章

编程入门先学什么(如何学会编程写代码)

编程入门先学什么最近有许多关于学习编程的争辩。不仅仅是由于与软件开发公司公开的待应聘的职位数量相比较契合招聘要求的人远远无法满足缺口,编程也是工资最高和工作满足感最强的许多职业之一。也难怪越来越多的人...

php7 安装mysqli实例讲解

本文操作环境:Windows7系统、php-7.1.5、Dell G3。php7 怎么安装mysqli?centos php7 安装mysqli扩展心得在新配服务器时发现,php无法连接到mysql。...

php中cookie与session的区别点总结

本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑无论是在系统运维还是 PHP 开发人员的面试中,经常会被问到 Session 和 Cookie 在 PHP 中的区别?下面我们就...

韩国站群服务器为什么受欢迎?韩国站群服务器推荐?

现在市面上有越来越多不同种类的服务器来针对不同种类的业务,对于站群业务来说由于ip的需求量大所以一般都是挑选站群服务器搭建业务,尤其是一些新网站做的主要是国内地区的流量,要想快速提升排名一般都首选搭建...

马来西亚服务器租用需要去国外吗?

马来西亚服务器租用需要去国外吗?不一定需要去国外租用马来西亚服务器。许多公司和服务提供商在马来西亚境内拥有数据中心和服务器,并提供租用计划。你可以通过互联网搜索或咨询IT服务提供商了解更多信息。如果你...

韩国服务器怎么样好用吗

韩国服务器怎么样好用吗?韩国服务器对于一些亚太区域的客户来说可能是一个不错的选择,它具有以下优点:稳定性高:韩国服务器的网络基础设施比较稳定,并且得到了政府的大力支持,因此能够提供稳定可靠的服务。带宽...