laravel csrf验证总结

admin3年前PHP教程75

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

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

相关文章

国外多IP服务器如何选择国外多ip服务器租用地址是多少

一、国外多IP服务器有什么用?1、容易被搜索引擎收录普通国外服务器可能只包含一个独立IP。如果很多网站都放在一个IP上,那么引擎就不会重视,甚至会被视为毫无价值的网站。国外多IP服务器提供多个独立IP...

XSS攻击有哪些攻击原理?美国高防服务器需要注意的有哪些?

什么是XSS攻击?XSS攻击通常指的是通过利用网页开发时留下的漏洞,通过巧妙的方法注入恶意指令代码到网页,使用户加载并执行攻击者恶意制造的网页程序。这些恶意网页程序通常是JavaScript,但实际上...

PHP引擎php.ini参数优化深入讲解

PHP引擎php.ini参数优化无论是apache还是nginx,php.ini都是适合的。而php-fpm.conf适合nginx+fcgi的配置首先选择产品环境的php.ini(php.ini-p...

美国站群服务器在资源方面的优点有什么

美国都知道是互联网发源地,在一些技术和互联网资源方面有着很高的优点,相比起国内或者其他地区的服务器而言,美国站群服务器这种资源优点更为明显,以下大家就举例美国站群服务器在资源方面的优点有什么?1、网络...

详解php处理大并发大流量大存储

一、判断大型网站的标准1、pv(page views)网页的浏览量概念 一个网站所有的页面,在24小时内被访问的总的次数。千万级别,百万级别,2、uv值(unique vistor)独立访客概念:一个...

美国大带宽服务器租赁费用是多少钱一个月

美国大带宽服务器租赁费用是多少钱一个月?美国大带宽服务器租赁的费用因供应商和服务计划而异,主要跟以下几个方面有关:带宽:服务器租赁的费用通常与所提供的带宽有关。带宽越高,费用也会相应越高。存储空间:租...