微信公众号初始化接入源代码

本文提供了微信公众号初始化接入的PHP代码示例。该代码通过验证签名确保安全性,并能响应不同类型的用户消息,如文本消息和关注事件。对于文本消息,会返回当前时间;对于新关注事件,则发送欢迎信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

微信公众号初始化接入代码


<?php
/**
  * wechat php test
  */
//define your token
define("TOKEN", "token");
$wechatObj = new wechatCallbackapiTest();
if(isset($_GET["echostr"])){
$wechatObj->valid();
}else{
$wechatObj->responseMsg();
}
 
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);
            $msgType = $postObj->MsgType;
            $time = time();
            switch( $msgType ){
                case "text";
                $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( $keyword =='时间' || $keyword =='time' || $keyword =="shijian"){
                    $contentStr = date("Y-m-d H:i:s",time());
                    $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                    echo $resultStr;
                }
                else
                {
                    $msgType = "text";
                    $contentStr = "欢迎关注xinshidaikexue";
                    $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                    echo $resultStr;
                }
 
                break;
 
                case "event":
                $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>";
                $event = $postObj->Event;
                $msgType = "text";
                if( $event =='subscribe'){
                    $contentStr = "欢迎关注xinshidaikexue";
 
                    $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                    echo $resultStr;
                    break;
                }
            }
 
        }else {
            echo "欢迎关注xinshidaikexue";
            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;
}
}
}
 
?> 


转载于:https://www.cnblogs.com/jjxhp/p/10433603.html

### DeepSeek 本地部署与微信集成操作指南 (适用于 Mac) #### 1. 准备工作 为了顺利在 macOS 上完成 DeepSeek 的本地部署以及后续的微信集成,需先确认已安装必要的依赖环境: - Python 3.x 及 pip 工具 - Docker Docker Compose - Git 客户端用于克隆项目仓库 确保以上组件均已正确配置完毕。 #### 2. 获取 DeepSeek 源码 打开终端应用,执行如下命令来获取官方提供的源代码包: ```bash git clone https://github.com/deepseek-labs/deploy.git ~/deepseek-deploy cd ~/deepseek-deploy ``` 此步骤会下载最新的稳定版本至用户的 home 目录下[^1]。 #### 3. 配置并启动服务 进入刚拉取下来的文件夹内,按照提示修改 `.env` 文件中的参数设置以适配个人需求。完成后运行以下指令初始化容器集群: ```bash docker-compose up -d --build ``` 这一步骤将会自动拉取所需镜像并在后台启动所有必要进程。 #### 4. 测试 API 功能 当看到日志输出显示 "Server is running on port..." 字样时即表示服务器已经成功上线。此时可以通过浏览器访问 `http://localhost:8080/docs` 来查看 Swagger UI 文档页面验证接口状态正常。 #### 5. 实现微信对接 对于希望进一步实现微信小程序或公众号功能扩展的情况来说,则需要额外引入 WeChaty SDK 库作为桥梁连接两者之间的通信链路。具体做法是在项目的根目录创建一个新的 Python 脚本来加载 WeChaty 并监听消息事件: ```python from wechaty import Wechaty, Message bot = Wechaty() @bot.on('message') async def on_message(msg:Message): content = msg.text() room = msg.room() or '' await bot.say(f'收到新消息来自 {room}: {content}') try: bot.start() except Exception as e: print(e) finally: bot.stop() ``` 上述脚本实现了最基本的聊天记录打印逻辑,实际应用场景中可根据业务特点定制更复杂的消息处理机制[^2]。 #### 6. 结合使用 最后将 WeChaty 所捕获到的信息转发给之前搭建好的 DeepSeek 后端做智能化分析响应即可达成完整的交互闭环效果[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值