【微信公众号开发】基于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)]

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

目录
相关文章
|
25天前
|
人工智能 JavaScript 定位技术
微信的接口都有哪些?
【10月更文挑战第17天】微信的接口都有哪些?
113 43
|
30天前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
449 7
|
30天前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
499 1
|
1月前
|
JSON 小程序 应用服务中间件
微信的接口wxLogin()的返回值都有什么?
【10月更文挑战第4天】微信的接口wxLogin()的返回值都有什么?
170 1
|
30天前
|
JSON 前端开发 API
使用微信JS-SDK调用发票接口的完整开发指南
本文介绍了如何使用微信JS-SDK的`chooseInvoiceTitle`接口来调用微信的发票功能。通过微信发票接口,用户可以选择开具个人或单位发票,并获取相关发票信息,如抬头、税号、公司地址等。在文中,详细描述了JS-SDK的初始化、发票接口的调用方式,并提供了完整的代码示例。文章还介绍了如何处理返回的发票信息,帮助开发者快速集成微信发票功能。
73 2
|
1月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
177 1
|
1月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
525 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
25天前
|
存储 小程序 安全
微信的开发管理都需要配置什么?
【10月更文挑战第17天】微信的开发管理都需要配置什么?
30 0
|
30天前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
305 0
|
1月前
|
小程序
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
449 0