美文网首页
解决yii2.0框架处理POST数据时因启用Csrf出现的400

解决yii2.0框架处理POST数据时因启用Csrf出现的400

作者: ArleyDu | 来源:发表于2016-09-03 11:20 被阅读86次

第一种解决办法是关闭Csrf
public function init()
{
$this->enableCsrfValidation = false;
}

第二种解决办法是在form表单中加入隐藏域
<input name="_csrf" type="hidden" id="_csrf" value="<?= Yii::$app->request->csrfToken ?>">

第三种解决办法是在AJAX中加入_csrf字段
在使用ajax的模板头部中加入<?php use yii\helpers\Html;?><?= Html::csrfMetaTags() ?>
然后就可以正常使用csrf了,如下所示:
var csrfToken = $('meta[name="csrf-token"]').attr("content");
$.ajax({
type: 'POST',
url: url,
data: {_csrf:csrfToken},
success: success,
dataType: dataType
});

相关文章

网友评论

      本文标题:解决yii2.0框架处理POST数据时因启用Csrf出现的400

      本文链接:https://www.haomeiwen.com/subject/lmvkettx.html