当前位置:首页 > PHP教程 > php应用 > 列表

启用Csrf后POST数据时出现的400错误

发布:smiling 来源: PHP粉丝网  添加日期:2021-06-08 16:19:18 浏览: 评论:0 

这篇文章主要介绍了启用Csrf后POST数据时出现的400错误的相关资料,需要的朋友可以参考下,最近一直出现这样的错误,一直在查找原因,偶然看到一篇解决的文章,分享给大家看看。

第一种解决办法是关闭Csrf

  1. public function init(){ 
  2.   $this->enableCsrfValidation = false; 

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

<input name="_csrf" type="hidden" id="_csrf" value="<?= Yii::$app->request->csrfToken ?>">

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

  1. var csrfToken = $('meta[name="csrf-token"]').attr("content"); 
  2. $.ajax({ 
  3.  type: 'POST'
  4.  url: url, 
  5.  data: {_csrf:csrfToken}, 
  6.  success: success, 
  7.  dataType: dataType 
  8. }); 

Yii这个匹配的过程和Yii::$app->request->csrfToken 这个值存储位置说明:

存储位置

  1. protected function createCsrfCookie($token
  2.   $options = $this->csrfCookie; 
  3.   $options['name'] = $this->csrfParam; 
  4.   $options['value'] = $token
  5.   return new Cookie($options); 

校验方法

  1. public function validateCsrfToken($token = null) 
  2.   $method = $this->getMethod(); 
  3.   // only validate CSRF token on non-"safe" methods http://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html#sec9.1.1 
  4.   if (!$this->enableCsrfValidation || in_array($method, ['GET''HEAD''OPTIONS'], true)) { 
  5.     return true; 
  6.   } 
  7.  
  8.   $trueToken = $this->loadCsrfToken(); 
  9.  
  10.   if ($token !== null) { 
  11.     return $this->validateCsrfTokenInternal($token$trueToken); 
  12.   } else { 
  13.     return $this->validateCsrfTokenInternal($this->getBodyParam($this->csrfParam), $trueToken
  14.       || $this->validateCsrfTokenInternal($this->getCsrfTokenFromHeader(), $trueToken); 
  15.   } 
  16. }

Tags: Csrf POST

分享到: