yii 2 局部关闭 CSRF 拦截

最近用yii2框架做ajax post传值时,报400错误,后来知道是csrf拦截

yii 2.0 内,对 CSRF 攻击做了处理,会对 post 提交的数据做 token 验证,而ajax post 到我们服务器的代码中,没有带上这个 token ,所以会验证失败

现在局部关闭csrf

新建一个Behavior  advanced\vendor\yiisoft\yii2\filters

复制代码
<?php
namespace yii\filters;

use Yii;
use yii\base\ActionEvent;
use yii\base\Behavior;
use yii\web\Controller;

class NoCsrf extends Behavior
{
    public $actions = [];
    public $controller;
    public function events()
    {
        return [Controller::EVENT_BEFORE_ACTION => 'beforeAction'];
    }
    public function beforeAction($event)
    {
        $action = $event->action->id;
        if(in_array($action, $this->actions)){
            $this->controller->enableCsrfValidation = false;
        }
    }
}
复制代码

然后在Controller中添加Behavior

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public function behaviors()
{
    return [
        'verbs' => [
            'class' => VerbFilter::className(),
            'actions' => [
                'delete' => ['POST'],
            ],
        ],
        'csfr' => [
            'class' => NoCsrf::className(),
            'controller' => $this,
            'actions' => [
                'prize'    //需要禁用csrf的方法
            ]
        ],
    ];
}

 其中,在控制器中要引用该类 use yii\filters\NoCsrf;

这样就实现了在action中关闭Csrf而不是在整个Controller中关闭。

 

posted @   沉潜蓄力  阅读(375)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
阅读排行:
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法
点击右上角即可分享
微信分享提示