laravel5.* 关闭指定路由的CsrfToken与常见csrf错误分析
Song •
2390 次浏览 •
0个评论 •
2018年03月10日
有时候你可能会希望一组URIs
和路由不要被CSRF
保护。例如:你开发Api接口让别人调用,你需要从Laravel
CSRF保护中排除
webhook的处理路由。可以在
app\Http\Middleware\VerifyCsrfToken.php中间件中增加
$except属性来排除
URIs(
5.3以后可定义在
API中,也没有
csrf`):
<?php
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as BaseVerifier;
class VerifyCsrfToken extends BaseVerifier
{
/**
* The URIs that should be excluded from CSRF verification.
*
* @var array
*/
protected $except = [
'/test_csrf',
];
}
这里我们需要关闭一个/test_csrf
的路由,这样csrf
就不需要{!! csrf_field() !!}
了
常见错误与解决办法
1、Illuminate\Session\TokenMismatchException in /var/www/test/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php:70
这个问题表示你的csrf验证失败,你可以关闭路由的csrf
,或者在表单中添加{!! csrf_field() !!}
或者<input name="_token" value="{{ csrf_token() }}"></input>
即可
-
laravel中distinct()的使用方法与去重 2017-09-11
-
Laravel将view缓存为静态html,laravel页面静态缓存 2021-10-09
-
[ laravel爬虫实战--基础篇 ] guzzle描述与安装 2017-11-01
-
[ 配置教程 ] 在ubuntu16.04中部署LNMP环境(php7+maridb且开启maridb远程以及nginx多域名访问 )并配置laravel环境 2017-07-18
-
laravel11如何启用routes/api.php无状态路由 2025-03-06
热门文章
-
laravel11如何启用routes/api.php无状态路由 2025-03-06
-
oppo手机默认浏览器urlscheme 2025-02-13
-
mysql如何给运营人员添加只有查询权限的账号 2024-12-02
-
Mac 安装mysql并且配置密码 2024-11-20
-
阿里云不同账号(跨账号)ECS服务器同地域如何实现免费内网互通? 2024-11-12
更多相关好文