PHP微信API接口页面代码
admin
2023-06-22 20:42:42
0
valid();
//(第二步启动回复功能)
$wechatObj->responseMsg();
//wechatCallbackapiTest类,主要用于微信开发验证与回复
class wechatCallbackapiTest
{
    //定义验证方法
public function valid()
    {
        //echostr随机字符串,接收随机字符串
        $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
//$GLOBALS可以接受xml数据.
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

      //extract post data
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 */
               //安全处理,解析xml时不解析外部实体,防止文件产生泄露(xxe泄露)
       libxml_disable_entity_loader(true);
              //载入xml文件到字符串
       $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
                //发送者(手机客户端)
       $fromUsername = $postObj->FromUserName;
       //接受者(微信公众号)
                $toUsername = $postObj->ToUserName;
                //定义一个接受类型
                $msgType=$postObj->MsgType;
                //接受到的关键词
                $keyword = trim($postObj->Content);
                //时间戳
                $time = time();
                //文本消息xml模板
                $textTpl = "

         
                            %s
                            
                             
                              0
                  ";  
                                    
if(!empty( $keyword ))
                {
              $msgType = "text";
                $contentStr = "欢迎来到崎沙火山岛旅游信息平台";
                $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                echo $resultStr;
                }else{
                echo "Input something...";
                }

        }else {
        echo "";
        exit;
        }
        
    }
//验证数字签名
private function checkSignature()
{
        // you must define TOKEN by yourself
        //校验TOKEN密钥
        if (!defined("TOKEN")) {
            throw new Exception('TOKEN is not defined!');
        }
        //接收数字签名
        $signature = $_GET["signature"];
        //接收时间戳
        $timestamp = $_GET["timestamp"];
        //接收随机数
        $nonce = $_GET["nonce"];
        //定义$token变量,接收TOKEN密钥
$token = TOKEN;
//把$token,$timestamp,$nonce组成数组
$tmpArr = array($token, $timestamp, $nonce);
        // use SORT_STRING rule
        //字典法排序
sort($tmpArr, SORT_STRING);
//转换数组为字符串
$tmpStr = implode( $tmpArr );
//通过哈希算法进行加密
$tmpStr = sha1( $tmpStr );
//与发送过来的数字签名$signature进行比对,成功则返回ture,否则返回false!
if( $tmpStr == $signature ){
return true;
}else{
return false;
}
}
}

?>





相关内容

热门资讯

凤凰晚报丨美国牡蛎养殖场,走出... 今日人物【美国牡蛎养殖场,走出一位特朗普“平替”】2026年5月,在美国缅因州波特兰举行的一场州民主...
胡锡进:记者暗访被打,我有这样... 一名女记者暗访助孕实验室遭粗暴对待,被拖拽骨折。警方已对这起故意伤害刑事立案调查。支持记协对该记者的...
福州一立体停车场闲置长草?当地... 澎湃新闻记者 王选辉在福建省福州市仓山区的金山文体中心旁,有一座立体停车库。近日有周边群众向澎湃新闻...
《微博AI内容生态报告》:金橙... 2026年5月28日,《微博AI内容生态报告》(以下简称“报告”)正式发布。本报告从微博平台视角出发...
把超级AI助理“戴”进日常 讯... (澳门,2026年5月28日)当下,人工智能正以全新软硬件形态重塑人机交互方式。5月28日,科大讯飞...
2026年演唱会拍清舞台手机推... 对于演唱会爱好者而言,最令人沮丧的莫过于花费重金抢到门票,却因为座位偏远,手机长焦无力,拍出的舞台画...
联通+联想携手 首款AI+eS... 2026年5月28日,中国联通与联想集团联合举办拯救者Y70新一代“AI+eSIM”游戏手机战略合作...
国家大基金领投DeepSeek... DeepSeek的模型迭代需要持续投入大规模训练算力,充足资金是支撑这一长周期投入的重要来源 文|《...
“武器系统成熟前不准造”,美国... 【文/观察者网 山猫】尽管最近传出了多个关于“特朗普”级战列舰项目似乎确实要开始着手实施的迹象,包括...
90后小伙徒步重走长征路,当事... “你相信人可以重生吗?肉体不可以,但我相信精神可以。”来自新疆的90后小伙王成于2025年10月10...