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

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

目录
相关文章
|
24天前
|
安全 前端开发 Java
基于springboot的微信公众号管理系统(支持多公众号接入)
基于springboot的微信公众号管理系统(支持多公众号接入)
26 2
|
1天前
|
小程序 前端开发 API
微信小程序全栈开发中的异常处理与日志记录
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的异常处理和日志记录,强调其对确保应用稳定性和用户体验的重要性。异常处理涵盖前端(网络、页面跳转、用户输入、逻辑异常)和后端(数据库、API、业务逻辑)方面;日志记录则关注关键操作和异常情况的追踪。实践中,前端可利用try-catch处理异常,后端借助日志框架记录异常,同时采用集中式日志管理工具提升分析效率。开发者应注意安全性、性能和团队协作,以优化异常处理与日志记录流程。
|
1天前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中PWA技术的应用,PWA结合Web的开放性和原生应用的性能,提供离线访问、后台运行、桌面图标和原生体验。开发者可利用Service Worker实现离线访问,Worker处理后台运行,Web App Manifest添加桌面图标,CSS和JavaScript提升原生体验。实践中需注意兼容性、性能优化和用户体验。PWA技术能提升小程序的性能和用户体验,助力开发者打造优质小程序。
|
1天前
|
小程序 安全 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的身份认证与授权机制。身份认证包括手机号验证、微信登录和第三方登录,而授权机制涉及角色权限控制、ACL和OAuth 2.0。实践中,开发者可利用微信登录获取用户信息,集成第三方登录,以及实施角色和ACL进行权限控制。注意点包括安全性、用户体验和合规性,以保障小程序的安全运行和良好体验。通过这些方法,开发者能有效掌握小程序全栈开发技术。
|
1天前
|
SQL 安全 小程序
探索微信小程序全栈开发的安全性问题
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的安全性问题,包括数据安全、接口安全、隐私保护和代码安全。为解决这些问题,建议采取数据加密、使用HTTPS协议、身份认证与授权、输入验证、安全审计及漏洞扫描以及安全培训等措施。通过这些方法,开发者可提升小程序安全性,保护用户隐私和数据。
|
1天前
|
JavaScript 前端开发 小程序
微信小程序全栈开发之性能优化策略
【4月更文挑战第12天】本文探讨了微信小程序全栈开发的性能优化策略,包括前端的资源和渲染优化,如图片压缩、虚拟DOM、代码分割;后端的数据库和API优化,如索引创建、缓存使用、RESTful API设计;以及服务器的负载均衡和CDN加速。通过这些方法,开发者可提升小程序性能,优化用户体验,增强商业价值。
|
23天前
|
小程序 JavaScript
在使用微信小程序开发中用vant2框架中的Uploader 文件上传wx.uploadFile无反应和使用多图上传
网上有的说是bind:after-read="afterRead"的命名问题不支持-,但是我这儿执行了console.log("file",file);证明函数运行了。后来发现是multiple="true"原因开启了多图上传,如果是多图上传的话file就是数组了
25 2
|
1月前
|
移动开发 JavaScript
微信公众号H5开发,在微信浏览器打开H5,无法一键下载图片
微信公众号H5开发,在微信浏览器打开H5,无法一键下载图片
28 0
|
1月前
|
移动开发 小程序 API
微信小程序的一些开发限制
微信小程序的一些开发限制
57 1
|
1月前
|
JSON 小程序 前端开发
微信小程序开发入门学习01-TDesign模板解读
微信小程序开发入门学习01-TDesign模板解读

热门文章

最新文章