首页 > 开发 > PHP > 正文

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

2024-05-04 23:37:20
字体:
来源:转载
供稿:网友

这篇文章主要介绍了启用Csrf后POST数据时出现的400错误的相关资料,需要的朋友可以参考下

最近一直出现这样的错误,一直在查找原因,偶然看到一篇解决的文章,分享给大家看看。

第一种解决办法是关闭Csrf

 

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

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

 

  1. <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. $trueToken = $this->loadCsrfToken(); 
  8.  
  9. if ($token !== null) { 
  10. return $this->validateCsrfTokenInternal($token, $trueToken); 
  11. else { 
  12. return $this->validateCsrfTokenInternal($this->getBodyParam($this->csrfParam), $trueToken) 
  13. || $this->validateCsrfTokenInternal($this->getCsrfTokenFromHeader(), $trueToken); 

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表