這篇文章中講述了在微信開發中遇到Token驗證失敗的解決方法,對微信開發感興趣的或者遇到過token驗證失敗解決不了的,都可以看看這篇文章哦!廢話少說,我們來進入正題吧!
微信小程式設定訊息推送的時候通常會出現Token驗證失敗的問題,這個錯誤是因為,你的介面頁面還沒有回饋正確的訊息給微信接口,網友們也給了一些解決方法,但有些能夠配置成功,有些則不然。下面給出網友提供的2種比較容易設定成功的php介面驗證程式碼。
程式碼範例一(我的驗證可以成功):
<?php //1. 将timestamp , nonce , token 按照字典排序 $timestamp = $_GET['timestamp']; $nonce = $_GET['nonce']; $token = "你自定义的Token值"; $signature = $_GET['signature']; $array = array($timestamp,$nonce,$token); sort($array); //2.将排序后的三个参数拼接后用sha1加密 $tmpstr = implode('',$array); $tmpstr = sha1($tmpstr); //3. 将加密后的字符串与 signature 进行对比, 判断该请求是否来自微信 if($tmpstr == $signature) { echo $_GET['echostr']; exit; }
程式碼範例二:
<?php /** * wechat php test */ //define your token define("TOKEN", "自定义token"); $wechatObj = new wechatCallbackapiTest(); $wechatObj->valid(); class wechatCallbackapiTest { public function valid() { $echoStr = $_GET["echostr"]; //valid signature , option if($this->checkSignature()){ echo $echoStr; exit; } } public function responseMsg() { //get post data, May be due to the different environments $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; //extract post data if (!empty($postStr)){ $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $fromUsername = $postObj->FromUserName; $toUsername = $postObj->ToUserName; $keyword = trim($postObj->Content); $time = time(); $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[%s]]></MsgType> <Content><![CDATA[%s]]></Content> <FuncFlag>0</FuncFlag> </xml>"; if(!empty( $keyword )) { $msgType = "text"; $contentStr = "Welcome to wechat world!"; $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr; }else{ echo "Input something..."; } }else { echo ""; exit; } } private function checkSignature() { $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $token = TOKEN; $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr); $tmpStr = implode( $tmpArr ); $tmpStr = sha1( $tmpStr ); if( $tmpStr == $signature ){ return true; }else{ return false; } } } ?>
以上兩種實例程式碼選擇一種直接上傳到你的伺服器上,在訊息配置中的url(伺服器位址寫上php檔案的伺服器位址),填入對應的自訂Token(令牌),訊息加密金鑰隨機產生即可,加密方式我的填了相容模式,數據格式隨個人喜好吧(我的填了JSON)。然後直接點選提交即可。如果出現下圖說明驗證通過了:
大家曾經遇到Token驗證錯誤的可以看看哦!幫助你更快的解決token的難題!
相關推薦:
以上是微信開發Token驗證失敗解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!