【微信公众号开发】基于golang的公众号开发——接入消息自动回复接口

简介: 【微信公众号开发】基于golang的公众号开发——接入消息自动回复接口

一、写在前头

  1. 该教程目标用户是想基于golang语言开发公众号后台,实现自动回复、微信支付、客服等等一些拓展功能;
  2. 需要会golang、gin、web服务的部署等基础知识。
  3. 关于微信开发的基本配置,请通过文末的链接查看。

二、整体思路

  1. 基于微信消息接口的逻辑,首先定义一个消息结构体;
  2. 然后解析微信服务器发送过来的消息;
  3. 根据消息的类型(MsgType字段)和消息的内容(Content字段)进行对应的处理;
  4. 关键字自动回复实例,通过switch-case 结构,将MsgType=text 并且 Content=关键字 的消息,回复对应的内容;

三、部分代码

package routers
import (
    "blog_server_v4/config"
    "crypto/sha1"
    "encoding/hex"
    "encoding/xml"
    "fmt"
    "github.com/gin-gonic/gin"
    "log"
    "net/http"
    "sort"
    "strings"
)
type ReqWxMessage struct {
    ToUserName   string `json:"ToUserName"`
    FromUserName string `json:"FromUserName"`
    CreateTime   int    `json:"CreateTime"`
    MsgType      string `json:"MsgType"` // text | image | voice | shortvideo | location
    Event        string `json:"Event"`
    EventKey     string `json:"EventKey"`
    Ticket       string `json:"Ticket"`
    // 文本消息
    Content   string `json:"Content"`
    MsgId     int64  `json:"MsgId"`
    MsgDataId int64  `json:"MsgDataId"`
    Idx       int    `json:"Idx"`
    // 图片消息
    PicUrl  string `json:"PicUrl"`
    MediaId string `json:"MediaId"`
    // 语音消息
    Format string `json:"Format"` // amr | speex
    // 视频消息
    ThumbMediaId string `json:"ThumbMediaId"`
    // 地理位置消息
    LocationX string `json:"Location_X"`
    LocationY string `json:"Location_Y"`
    Scale     string `json:"Scale"`
    Label     string `json:"Label"`
    // 链接消息
    Title       string `json:"Title"`
    Description string `json:"Description"`
    Url         string `json:"Url"`
}
type RespWxMessageText struct {
    ToUserName   string   `json:"ToUserName"`
    FromUserName string   `json:"FromUserName"`
    CreateTime   int      `json:"CreateTime"`
    MsgType      string   `json:"MsgType"`
    Content      string   `json:"Content"`
    XMLName      xml.Name `xml:"xml"`
}
func RouterPartner(router *gin.Engine) (interface{}, error) {
    routerPartner := router.Group("/xxx/xxxx")
    {
        routerPartner.POST("/xxx/xxxx/v1", func(c *gin.Context) {
            signature := c.Query("signature")
            timestamp := c.Query("timestamp")
            nonce := c.Query("nonce")
            openid := c.Query("openid")
            log.Println("signature:", signature, "timestamp:", timestamp, "nonce:", nonce, "openid:", openid)
            var wxMsg ReqWxMessage
            err := c.BindXML(&wxMsg)
            if err != nil {
                log.Println(err)
            }
            //log.Println("mxMsg:", wxMsg)
            //byteWxMsg, err := json.Marshal(wxMsg)
            //if err != nil {
            //  log.Println("err: ", err)
            //}
            //log.Println("wxMsgString: ", string(byteWxMsg))
            switch wxMsg.MsgType {
            case "text":
                if strings.ToLower(wxMsg.Content) == "pdf2023" {
                    respWxMessageText := RespWxMessageText{
                        ToUserName:   wxMsg.FromUserName,
                        FromUserName: wxMsg.ToUserName,
                        CreateTime:   wxMsg.CreateTime + 1,
                        MsgType:      "text",
                        Content: `链接:https://pan.baidu.com/s/1FYKllrdbZDNc5BxxLv9mcQ?pwd=pryf
                    提取码:pryf
                    --来自百度网盘超级会员V5的分享`,
                    }
                    byteResp, err := xml.Marshal(&respWxMessageText)
                    if err != nil {
                        log.Println(err)
                        break
                    }
                    c.String(http.StatusOK, string(byteResp))
                    //
                    //log.Println(string(byteResp))
                    return
                }
            }
            c.String(http.StatusOK, "success")
            return
        })
    }
    return routerPartner, nil
}

关键点说明

  1. 返回的数据需要需要用 c.String() 返回,不能使用c.XML()
  2. 返回给微信的xml字符串,最外层应当是<xml> 标签,不能使用默认的标签,因此,在定义结构体时,需要使用xml:"xml" 指定xml标签

四、校验

[图片上传失败...(image-107571-1699711050225)]

可以看到微信公众号对话窗口和服务端处理窗口的时间是能对上的,即校验成功。

目录
相关文章
ly~
|
7天前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
38 6
|
6天前
|
小程序 JavaScript API
微信小程序开发学习之页面导航(声明式导航和编程式导航)
这篇文章介绍了微信小程序中页面导航的两种方式:声明式导航和编程式导航,包括如何导航到tabBar页面、非tabBar页面、后退导航,以及如何在导航过程中传递参数和获取传递的参数。
微信小程序开发学习之页面导航(声明式导航和编程式导航)
|
2月前
|
小程序 JavaScript
Taro@3.x+Vue@3.x+TS开发微信小程序,使用轮播图
本文介绍了使用 Taro 和 Vue 创建轮播组件的两种方法:一是通过 `&lt;swiper&gt;` 实现,二是利用 Nut UI 的 `&lt;nut-swiper&gt;` 组件实现。
Taro@3.x+Vue@3.x+TS开发微信小程序,使用轮播图
|
20天前
|
存储 移动开发 监控
微信支付开发避坑指南
【9月更文挑战第11天】在进行微信支付开发时,需遵循官方文档,确保权限和参数配置正确。开发中应注重安全,验证用户输入,合理安排接口调用顺序,并处理异常。上线后需实时监控支付状态,定期检查配置,关注安全更新,确保系统稳定运行。
|
27天前
|
移动开发 小程序 JavaScript
uni-app开发微信小程序
本文详细介绍如何使用 uni-app 开发微信小程序,涵盖需求分析、架构思路及实施方案。主要功能包括用户登录、商品列表展示、商品详情、购物车及订单管理。技术栈采用 uni-app、uView UI 和 RESTful API。文章通过具体示例代码展示了从初始化项目、配置全局样式到实现各页面组件及 API 接口的全过程,并提供了完整的文件结构和配置文件示例。此外,还介绍了微信授权登录及后端接口模拟方法,确保项目的稳定性和安全性。通过本教程,读者可快速掌握使用 uni-app 开发微信小程序的方法。
57 3
|
1月前
|
Go API
Golang语言开发注意事项
这篇文章总结了Go语言开发中的注意事项,包括语法细节、注释使用、代码风格、API文档的利用以及如何使用godoc工具来生成文档。
23 2
|
2月前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,设置转发分享
本文介绍了Taro中`useShareAppMessage`的使用方法,需在页面配置`enableShareAppMessage: true`并重新编译。
Taro@3.x+Vue@3.x+TS开发微信小程序,设置转发分享
|
2月前
|
小程序 数据安全/隐私保护
Taro@3.x+Vue@3.x+TS开发微信小程序,网络请求封装
在 `src/http` 目录下创建 `request.ts` 文件,并配置 Taro 的网络请求方法 `Taro.request`,支持多种 HTTP 方法并处理数据加密。
Taro@3.x+Vue@3.x+TS开发微信小程序,网络请求封装
|
2月前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件
本文介绍如何在Taro项目中使用Nut UI的`&lt;nut-uploader/&gt;`组件实现图片上传功能,并通过示例代码展示了自定义上传逻辑的方法。
Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件
|
2月前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
本文介绍如何在Taro项目中配置深色模式。通过在`src/app.config.ts`设置`darkmode`选项和在`theme.json`中定义主题变量,可以实现跟随系统主题的界面风格切换。
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
下一篇
无影云桌面