濮阳杆衣贸易有限公司

主頁 > 知識庫 > PHP實現(xiàn)微信公眾號驗證Token的示例代碼

PHP實現(xiàn)微信公眾號驗證Token的示例代碼

熱門標簽:青島語音外呼系統(tǒng)招商 山西回撥外呼系統(tǒng) 昭通辦理400電話 百應(yīng)電話機器人服務(wù) 河南電銷卡外呼系統(tǒng)哪家強 揚州地圖標注app 騰訊外呼管理系統(tǒng) 山西探意電話機器人 岳陽外呼型呼叫中心系統(tǒng)在哪里
  • 難度水平:初中級
  • 適用人群:對微信公眾號開發(fā)有認知跟實踐的童鞋
  • 閱讀時間:8分鐘

緣起

很久之前做過一次公眾號的開發(fā),當時就遇到了一個驗證的小坑,但是由于時間緊任務(wù)急處理完了也就沒在意,可誰知最近剛剛上馬一個新的公眾號項目又遇到了同樣的小坑,痛定思痛決定奮筆疾書留下痕跡,省的以后再次忘記了。😁

開始驗證

首先來一張勝過千言萬語的圖,說明我們要驗證的目標:

然后開始掃坑。先掃個盲,微信驗證的目的就是你來證明你的服務(wù)器地址的有效性,所以帶著這個目的我們來看看下面這些問題:

  • URL地址怎么寫
  • 純PHP的代碼怎么寫
  • Laravel的代碼怎么寫
  • 常見的坑是什么

URL地址怎么寫

這個地址可以是路由地址也可以是文件地址:

路由地址形式:
https://mydomain.com/wx,
https://mydomain.com/auth/wx,
https://mydomain.com/utility/wx

文件地址形式:
https://mydomain.com/mywechat...
https://mydomain.com/auth/myw...
https://mydomain.com/utility/...

敲黑板,劃重點:
無論哪種形式都可以,重點是可以直接通過GET或者POST訪問到

純PHP的代碼怎么寫

通常來說純代碼就是非框架的php代碼驗證方式,廢話少說,直接上酸菜:

/*這個是你自定義的令牌,圖片里面Token的位置*/
define("TOKEN", "這個是你自定義的令牌");
/*初始化當前的類*/
$wechatObj = new wechatCallbackapiTest();
/*開始驗證程序*/
$wechatObj->valid();
/**
 * Class WXApiVerify
 */
class WXApiVerify
{
  /**
   * 檢測函數(shù)輸出
   */
  public function valid()
  {
    $echoStr = $_GET['echostr'];
    if($this->checkSignature()){
      echo $echoStr; #坑點,看下面的常見坑介紹
      exit; #一定要停止php運行,避免產(chǎn)生不必要的字串符
    }
  }

  /**
   * 前面檢測
   * @return bool
   */
  private function checkSignature()
  {
    #注意: 這里可以不用檢驗$_GET參數(shù)的有效性,因為微信一定會傳相關(guān)的參數(shù)給你的服務(wù)器的,你直接開啟驗證模式即可。
    $signature = $_GET['signature'];
    $timestamp = $_GET['imestamp'];
    $nonce = $_GET['nonce'];
    $token = TOKEN;
    $tmpArr = array($token, $timestamp, $nonce);
    sort($tmpArr, SORT_STRING);
    $tmpStr = implode( $tmpArr );
    $tmpStr = sha1( $tmpStr );
    if( $tmpStr === $signature ){
      return true;
    }else{
      return false;
    }
  }
}

Laravel的代碼怎么寫

首先,強勢插個口播(在使用過TP5,CodeIgniter, CakePHP, Yii, Slim之后,我認為Laravel是目前來說最好的PHP框架,不接受其他任何意見。)
其次,驗證代碼上面是跟純PHP大同小異的,唯一的區(qū)別是在你處理POST請求的時候一定要讓Laravel不要檢測CSFR Token,否則會出現(xiàn)錯誤。

首先,設(shè)置路由:

Route::any('wx', [
  'uses' => 'WeChatApp@checkSignature'
]);
#坑點,看下面的常見坑介紹

其次,取消Laravel的CSFR檢查:

#去到你的Middlewarel里面找到VerifyCsrfToken.php然后插入下面代碼:
protected $except = [
    'wx', #注意這個是你在第一步設(shè)置的路由路徑,不接受單獨的文件路徑,太Low逼了
  ];

最后,上酸菜:

#在你對應(yīng)的Controller里面加入以下函數(shù)
  public function checkSignature( Request $request ) {
    $input = $request->all();
    # 一定要抓取4個參數(shù)
    $echoStr  = $input[ "echostr" ];
    $signature = $input[ "signature" ];
    $timestamp = $input[ "timestamp" ];
    $nonce   = $input[ "nonce" ];
    # 微信官方驗證方式
    $token = env( 'TOKEN' ); #或者用config()函數(shù)
    $tmpArr = [ $token, $timestamp, $nonce ];
    sort( $tmpArr, SORT_STRING );
    $tmpStr = implode( $tmpArr );
    $tmpStr = sha1( $tmpStr );
    
    # 打印返回結(jié)果
    if( $tmpStr == $signature ){
      return response($echoStr);
    } else{
      return response();
    }
  }

常見的坑是什么

文檔坑。有些人看過官方文檔之后直接就上代碼了,缺忽略了里面的一個參數(shù)echostr 隨機字符串 而這個恰恰是驗證服務(wù)器的關(guān)鍵點,你要打印這個返回給微信才能通過驗證。但是官方文檔說的不夠重點。

Laravel路由坑。一定要設(shè)置請求為any這樣包括(GET跟POST)

Laravel還有一個測試的坑,就是如果你的APP_DEBUG=false如果不是false的話可能會造成拋出多余的字串導(dǎo)致驗證失敗。

要學(xué)會使用微信官方測試工具 https://mp.weixin.qq.com/debug/ 選擇消息接口測試文本消息接口就行。其他的可以看圖說話

微信UI的坑。在你通過上面的測試后,并不真正代表你啟用了服務(wù)器。而是在你保存后要點擊啟用,然后看到紅色 停用 才真正的是真正的啟用了。

白名單坑。你一定要去到微信的安全中心設(shè)置你的服務(wù)器的白名單.否則之后的開發(fā)工作會有阻礙。

公眾號設(shè)置坑。你一定要去微信的公眾號設(shè)置里面加入你的:

  • 業(yè)務(wù)域名
  • JS接口安全域名
  • 網(wǎng)頁授權(quán)域名

結(jié)語

微信開發(fā)有挑戰(zhàn),細心最關(guān)鍵。遇到問題不要慌,來看哥文章。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php微信公眾號開發(fā)模式詳解
  • php實現(xiàn)微信公眾號創(chuàng)建自定義菜單功能的實例代碼
  • PHP實現(xiàn)的微信公眾號掃碼模擬登錄功能示例
  • 微信公眾平臺開發(fā)教程③ PHP實現(xiàn)微信公眾號支付功能圖文詳解
  • php微信公眾號開發(fā)之快遞查詢
  • php微信公眾號開發(fā)之校園圖書館
  • php微信公眾號開發(fā)之歡迎老朋友
  • php微信公眾號開發(fā)之關(guān)鍵詞回復(fù)
  • php微信公眾號開發(fā)之圖片回復(fù)
  • 基于PHP的微信公眾號的開發(fā)流程詳解

標簽:黃南 南陽 婁底 湛江 銅川 鎮(zhèn)江 宜賓 寶雞

巨人網(wǎng)絡(luò)通訊聲明:本文標題《PHP實現(xiàn)微信公眾號驗證Token的示例代碼》,本文關(guān)鍵詞  PHP,實現(xiàn),微信,公眾,號,驗證,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實現(xiàn)微信公眾號驗證Token的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP實現(xiàn)微信公眾號驗證Token的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    四子王旗| 华阴市| 奇台县| 东阳市| 长沙市| 祁东县| 尚志市| 汽车| 陈巴尔虎旗| 隆子县| 天气| 巩义市| 盘锦市| 蒙自县| 龙江县| 尚义县| 旺苍县| 上虞市| 民权县| 景泰县| 铜陵市| 大港区| 江山市| 广元市| 弥渡县| 彰化县| 休宁县| 贵溪市| 封丘县| 南川市| 新龙县| 常德市| 五大连池市| 腾冲县| 南昌市| 安阳市| 子长县| 庆云县| 紫阳县| 江都市| 仁寿县|