yii2使用gii生成的搜索视图里的表单使用的是get方式,我改为post就提示无法验证,以为是控制器默认访问是get,实际默认是get和post都可以

public function behaviors()
    {
        return [
            'verbs' => [
                'class' => VerbFilter::className(),
                'actions' => [
                    'delete' => ['post'],
                ],
            ],
        ];
    }

  

之所以提示无法验证是因为对于post请求,是有一个CSRF验证的

解决POST数据时因启用Csrf出现的400错误

第一种解决办法是关闭Csrf

public function init()
{
    $this->enableCsrfValidation = false;
}
//或者
public function __construct($id, $module, $config = [])
{
    $this->menuActive = 2;
    $this->enableCsrfValidation = false;
    parent::__construct($id, $module, $config);      
         
}
//总之把enableCsrfValidation设为false就可以了

  第二种解决办法是在form表单中加入隐藏域

<input name="_csrf" type="hidden" >

  第三种解决办法是在AJAX中加入_csrf字段

var csrfToken = $('meta[name="csrf-token"]').attr("content");
$.ajax({
    type: 'POST',
    url: url,
    data: {
        _csrf:csrfToken},
        success: success,
        dataType: dataType
});

  

相关文章:

  • 2022-12-23
  • 2021-10-27
  • 2022-12-23
  • 2021-05-04
  • 2021-07-19
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-08-05
  • 2022-12-23
  • 2022-12-23
  • 2021-05-09
  • 2021-12-12
相关资源
相似解决方案