我們知道使用回調模式來開發企業號總是出現錯誤,那麼這次就給大家帶來PHPPHP開發之關於回調模式的錯誤問題解決方案,一起看一下。
其實開發文檔說的確實十分詳細了,而且使用官方給的demo,只要做稍稍的改變就可以直接用了。但是為什麼總是提示錯誤呢?
下面我先貼出我驗證成功的回調模式開啟的代碼
<?php//回調開啟include_once "WXBizMsgCrypt.php";// 假設企業號在公眾平台上設定的參數如下$encodingAesKey = "xxx";$token = "xxx";$corpId = "xxx";//填寫自己的相關參數,與公眾平台一致/*------------使用樣本一:驗證回調URL---------------*企業開啟回調模式時,企業號會向驗證url發送一個get請求假設點擊驗證時,企業收到類似請求:* GET /cgi-bin/wxpush?msg_signature=5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3×tamp=1409659589&nonce=263014780&echostr=P9nAzCzyDtyTWESHep1vC5X9xho%2FqYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp%2B4RPcs8TgAE7OaBO%2BFZXvnaqQ%3D%3D* HTTP/1.1 Host: qy.weixin.qq.com接收到該請求時,企業應1.解析出Get請求的參數,包括訊息體簽名(msg_signature),時間戳記(timestamp),隨機數字串(nonce)以及公眾平台推送過來的隨機加密字串(echostr),這一步注意作URL解碼。2.驗證訊息體簽名的正確性3. 解密出echostr原文,將原文當作Get請求的response,返回給公眾平台第2,3步可以用公眾平台提供的庫函數VerifyURL來實現。*/// $sVerifyMsgSig = HttpUtils.ParseUrl("msg_signature");$sVerifyMsgSig = $_GET["msg_signature"] ;//"5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3";// $sVerifyTimeStamp = HttpUtils.ParseUrl("timestamp");$sVerifyTimeStamp = $_GET["timestamp"];//"1409659589";// $sVerifyNonce = HttpUtils.ParseUrl("nonce");$sVerifyNonce = $_GET["nonce"];//"263014780";// $sVerifyEchoStr = HttpUtils.ParseUrl("echostr");$sVerifyEchoStr = $_GET["echostr"];//"P9nAzCzyDtyTWESHep1vC5X9xho/qYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp+4RPcs8TgAE7OaBO+FZXvnaqQ==";// 需要返回的明文$EchoStr = "";$wxcpt = new WXBizMsgCrypt($token, $encodingAesKey, $corpId);$errCode = $wxcpt->VerifyURL($sVerifyMsgSig, $sVerifyTimeStamp, $sVerifyNonce, $sVerifyEchoStr, $sEchoStr);if ($errCode == 0) { echo $sEchoStr; // // 驗證URL成功,將sEchoStr返回 // HttpUtils.SetResponce($sEchoStr);} else { print("ERR: " . $errCode . "\n\n");}
可見以上代碼和demo給的基本一致,在一天前相同的代碼也驗證不成功的,經過研究發現:驗證url時的網域名稱必須是可信網域名稱。ps:我用的是新浪雲,但是我沒有進行實名認證,所以存在風險,當我實名認證後,就開啟成功了。
感悟:官方文檔什麼時候都不會錯,好好研讀官方文檔很有必要。在企業號--回調模式開啟的過程中,網域名稱必須是可信網域名稱,這點也非常重要。
相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
相關閱讀:
執行個體講解Ajax非同步請求技術
AJAX的常用文法是什麼
AJAX原理與CORS跨域的方法