溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP微信API接口類的示例分析

發(fā)布時(shí)間:2021-08-31 14:15:23 來源:億速云 閱讀:124 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹PHP微信API接口類的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

具體內(nèi)容如下

<?php
/**
 * wechat php test
 */
 
//define your token
//定義TOKEN秘鑰
define("TOKEN", "weixin");
 
//實(shí)例化微信對(duì)象
$wechatObj = new wechatCallbackapiTest();
//驗(yàn)證成功后注釋valid方法
//$wechatObj->valid();
//開啟自動(dòng)回復(fù)功能
$wechatObj->responseMsg();
 
 
//定義類文件
class wechatCallbackapiTest
{
  //實(shí)現(xiàn)valid驗(yàn)證方法:實(shí)現(xiàn)對(duì)接微信公眾平臺(tái)
  public function valid()
  {
    //接受隨機(jī)字符串
    $echoStr = $_GET["echostr"];
 
    //valid signature , option
    //進(jìn)行用戶數(shù)字簽名驗(yàn)證
    if($this->checkSignature()){
      //如果成功,則返回接受到的隨機(jī)字符串
      echo $echoStr;
      //退出
      exit;
    }
  }
  //定義自動(dòng)回復(fù)功能
  public function responseMsg()
  {
    //get post data, May be due to the different environments
    //接受用戶端發(fā)送過來的xml數(shù)據(jù)
    $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];
 
    //extract post data
    //判斷xml數(shù)據(jù)是否為空
    if (!empty($postStr)){
        /* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection,
          the best way is to check the validity of xml by yourself */
        libxml_disable_entity_loader(true);
        //通過simplexml進(jìn)行xml解析
        $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
        //接受微信的手機(jī)端
        $fromUsername = $postObj->FromUserName;
        //微信公眾平臺(tái)
        $toUsername = $postObj->ToUserName;
        //接受用戶發(fā)送的關(guān)鍵詞
        $keyword = trim($postObj->Content);
        //1.接受用戶消息類型
        $msgType = $postObj -> MsgType;
        //時(shí)間戳
        $time = time();
        //文本發(fā)送模板
        $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>"; 
        //////////////////////////////////////////////////////////////////////////////////
        //如果用戶發(fā)送的是文本類型文件,執(zhí)行以下
        if($msgType == 'text'){
          if(!empty( $keyword ))
          {
            /*這是一個(gè)實(shí)例
              //如果發(fā)送文本信息
              $msgType = "text";
              //回復(fù)內(nèi)容
              if($keyword == "李楠"){
                $contentStr = "叫我干嘛";
              }else{
                $contentStr = "叫我干嘛";
              }
              //格式化xml模板,參數(shù)與上面的模板是一一對(duì)應(yīng)的.fromUsername和頭Username是相反的,只寫帶%s的
              $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
 
              //將xml信息返回給客戶端
              echo $resultStr;
            */
            if($keyword == "?" || $keyword == "?"){
              $msgType = "text";
              $contentStr = "1.特種服務(wù)號(hào)碼\n2.通訊服務(wù)號(hào)碼";
              $resultStr = sprintf($textTpl,$fromUsername,$toUsername,$time,$msgType,$contentStr);
              echo $resultStr;
            }elseif($keyword == 1){
              $msgType = "text";
              $contentStr = "1.匪警:110\n2.火警:119\n3.急救:120";
              $resultStr = sprintf($textTpl,$fromUsername,$toUsername,$time,$msgType,$contentStr);
              echo $resultStr;
            }elseif($keyword == 2){
              $msgType = "text";
              $contentStr = "1.中國(guó)移動(dòng):10086\n2.中國(guó)聯(lián)通:10010";
              $resultStr = sprintf($textTpl,$fromUsername,$toUsername,$time,$msgType,$contentStr);
              echo $resultStr;
            }
          }else{
            echo "不能不說話";
          }
        }
        ////////////////////////////////////////////////////////////////////////////////////
        //接受圖片信息
        if($msgType == "image"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是圖片文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        if($msgType == "voice"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是語音文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        if($msgType == "video"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是視頻文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        if($msgType == "shortvideo"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是小視頻文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        if($msgType == "location"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是地理位置文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        if($msgType == "link"){
            //如果發(fā)送文本信息
            $msgType = "text";
            //回復(fù)內(nèi)容
            $contentStr = "你發(fā)送的是連接文件";
            //格式化字符串
            $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
            //將xml信息返回給客戶端
            echo $resultStr;
        }
        ////////////////////////////////////////////////////////////////////////////////////
        /*
        //判斷用戶發(fā)送關(guān)鍵詞是否為空      
         
        if(!empty( $keyword ))
        {
          //如果發(fā)送文本信息
          $msgType = "text";
          //回復(fù)內(nèi)容
          $contentStr = "大家好,我是hero";
          //格式化字符串
          $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
          //將xml信息返回給客戶端
          echo $resultStr;
        }else{
          echo "Input something...";
        }
        */
    }else {
      echo "";
      exit;
    }
  }
     
  private function checkSignature()
  {
    // you must define TOKEN by yourself
    //判斷是否定義了TOKEN,如果沒有就拋出一個(gè)異常
    if (!defined("TOKEN")) {
      throw new Exception('TOKEN is not defined!');
    }
     
    $signature = $_GET["signature"];//接受微信加密簽名
    $timestamp = $_GET["timestamp"];//接受時(shí)間戳
    $nonce = $_GET["nonce"];//接受隨機(jī)數(shù)
         
    $token = TOKEN;//把TOKEN常量賦值給$token
    //把相關(guān)參數(shù)組裝成數(shù)組
    $tmpArr = array($token, $timestamp, $nonce);
    // use SORT_STRING rule
    //排序
    sort($tmpArr, SORT_STRING);
    //把排序后的數(shù)組轉(zhuǎn)換成字符串
    $tmpStr = implode( $tmpArr );
    //通過哈希算法加密
    $tmpStr = sha1( $tmpStr );
    //與加密簽名進(jìn)行對(duì)比
    if( $tmpStr == $signature ){
      //相同返回true
      return true;
    }else{
      //不同返回false
      return false;
    }
  }
}
 
?>

以上是“PHP微信API接口類的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI