public function valid() { if (isset($_GET["echostr"])) { $echoStr = $_GET["echostr"]; //valid signature , option if (!$this->token) { throw new Exception('token is not defined!'); } $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $tmpArr = array($this->token, $timestamp, $nonce); // use SORT_STRING rule sort($tmpArr, SORT_STRING); $tmpStr = implode($tmpArr); $tmpStr = sha1($tmpStr); if ($tmpStr == $signature) { ob_clean(); echo $_GET['echostr']; } else { echo 'xx'; } } else { $this->responseMsg(); } }
解决办法:在输出 echc $_GET['echostr']; 前,清空缓存区,即在echo 前放置“ob_clean();”代码即可。
官方解释:ob_clean(); 此函数是用来丢弃输出缓冲区中的内容;
完成以后,即可配置成功:
原文地址:https://www.cnblogs.com/Mishell/p/12618700.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。