首页 > 编程语言 >GO语言实战-小程序或公众号接口gin框架验证微信服务器消息签名

GO语言实战-小程序或公众号接口gin框架验证微信服务器消息签名

时间:2022-11-09 16:00:43浏览次数:44  
标签:string 微信 json sha1String token GO gin

在开发GO小程序或者公众号接口的时候,需要对接微信消息的token签名验证 , 这时候需要开发者验证来自微信 , 并返回指定的字符串

微信文档里给的是PHP版本的代码 , 下面这个是go版本的代码 , 使用的gin框架

这个是入口的路由 ,根据自己的代码来写就可以 , 注意发来的是GET请求

package router

import (
    "github.com/gin-gonic/gin"
    "github.com/taoshihan1991/imaptool/controller"
)

func InitApiRouter(engine *gin.Engine){
    engine.GET("/micro_program",controller.GetCheckWeixinSign)
}

  验证代码 , 这里只有一个需要把微信公众号后台填写的token , 自己换上 , 其他都是对方发来的消息

package controller

import (
    "crypto/sha1"
    "encoding/hex"
    "github.com/gin-gonic/gin"
    "github.com/taoshihan1991/imaptool/config"
    "log"
    "sort"
)

func GetCheckWeixinSign(c *gin.Context){
    token:="xxxxxxxx"//自己填的token
    signature:=c.Query("signature")
    timestamp:=c.Query("timestamp")
    nonce:=c.Query("nonce")
    echostr:=c.Query("echostr")
    //将token、timestamp、nonce三个参数进行字典序排序
    var tempArray  = []string{token, timestamp, nonce}
    sort.Strings(tempArray)
    //将三个参数字符串拼接成一个字符串进行sha1加密
    var sha1String string = ""
    for _, v := range tempArray {
        sha1String += v
    }
    h := sha1.New()
    h.Write([]byte(sha1String))
    sha1String = hex.EncodeToString(h.Sum([]byte("")))
    //获得加密后的字符串可与signature对比
    if sha1String == signature {
        c.Writer.Write([]byte(echostr))
    } else {
        log.Println("微信API验证失败")
    }
}

  在公众号后台验证时 , 弹出来绿色的验证成功标识后就可以了,下面是完整代码:

package main

import (
	"crypto/sha1"
	"encoding/hex"
	"fmt"
	"github.com/gin-gonic/gin"
	"net/http"
	"sort"
)

func main() {
	gin.SetMode(gin.DebugMode) //全局设置环境,此为开发环境,线上环境为gin.ReleaseMode
	router := gin.Default()    //获得路由实例

	//添加中间件
	router.Use(Middleware)
	//注册接口
	router.GET("/wechat/server", GetCheckWeixinSign) // 这个是微信验证
	router.POST("/wechat/server", PostHandler)       // 这个是微信验证
	//监听端口
	http.ListenAndServe(":8889", router)
}

// WXTextMsg 微信文本消息结构体
type WXTextMsg struct {
	ToUserName              string `json:"ToUserName"`
	FromUserName            string `json:"FromUserName"`
	CreateTime              string `json:"CreateTime"`
	MsgType                 string `json:"MsgType"`
	Event                   string `json:"Event"`
	SubscribeMsgChangeEvent struct {
		List struct {
			TemplateID            string `json:"TemplateId"`
			SubscribeStatusString string `json:"SubscribeStatusString"`
		}
	}
}

func PostHandler(c *gin.Context) {
	var textMsg WXTextMsg
	//err := c.BindXML.ShouldBindXML(&textMsg)
	err := c.BindXML(&textMsg)
	if err != nil {
		fmt.Printf("[消息接收] - XML数据包解析失败: %v\n", err)
		return
	}

	fmt.Printf("[消息接收] - 收到消息, 消息为: ", textMsg)

	type JsonHolder struct {
		Id   int    `json:"id"`
		Name string `json:"name"`
	}

	holder := JsonHolder{Id: 1, Name: "my name"}
	//若返回json数据,可以直接使用gin封装好的JSON方法
	c.JSON(http.StatusOK, holder)
	return
}

func GetCheckWeixinSign(c *gin.Context) {
	token := "xxxxxxxxxxx" //自己填的token
	signature := c.Query("signature")
	timestamp := c.Query("timestamp")
	nonce := c.Query("nonce")
	echostr := c.Query("echostr")
	//将token、timestamp、nonce三个参数进行字典序排序
	var tempArray = []string{token, timestamp, nonce}
	sort.Strings(tempArray)
	//将三个参数字符串拼接成一个字符串进行sha1加密
	var sha1String string = ""
	for _, v := range tempArray {
		sha1String += v
	}
	h := sha1.New()
	h.Write([]byte(sha1String))
	sha1String = hex.EncodeToString(h.Sum([]byte("")))
	//获得加密后的字符串可与signature对比
	if sha1String == signature {
		c.Writer.Write([]byte(echostr))
	} else {
		fmt.Println("微信API验证失败")
	}
}

func Middleware(c *gin.Context) {
	fmt.Println("this is a middleware!")
}

  

 

标签:string,微信,json,sha1String,token,GO,gin
From: https://www.cnblogs.com/adjk/p/16874016.html

相关文章

  • 大数据开发:Go中的方法
    我们知道Go中没有继承,接口的用法也与Java中的用法大相径庭,很多适合,我们需要使用OO的思想来组织我们达到项目,但是将Java的oo思想在Go中会比较痛苦,Go中的方法和面向对象的类......
  • 0009.Django请求与响应
    HttpRequest对象服务器接受到http协议的请求后,会根据报文创建HttpRequest对象视图函数的第一个参数是HttpRequest对象在django.http模型中定义了HttpRequest对象的API......
  • Nginx配置文件详解
    Nginx的主配置文件是nginx.conf,这个配置文件一共由三部分组成,分别为全局块、events块和http块。在http块中,又包含http全局块、多个server块。每个server块中,可以包含server......
  • django一些常用命令
    django一些常用命令#创建项目django-adminstartprojectmysite#创建app,创建成功项目以后,cd进入mysitepythonmanage.pystartappapp01#数据库迁移命令pythonmanage.p......
  • django-cors-headers实现跨域的方法总结
    django-cors-headers实现跨域的方法总结在setting.py中配置INSTALLED_APPS=['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.cont......
  • TDengine:国内4家大型物流公司的数据架构改造实例汇总
    对于物流企业来说,如何高效地记录和处理车辆的轨迹信息、应对每天海量监控数据的采集和处理工作,对于项目整体的交付效率至关重要。同时,伴随着数字化、智能化的不断加速,数据......
  • 微信小程序使用新版Canvas画布实现电子签名
    <viewclass="containercolumn-me"><viewclass="tips">请绘制清晰可见的签名并保存</view><canvasclass="canvas"id="canvas"type="2d"disable-scrol......
  • BigInteger,BigDecimal
    BigInteger方法名说明publicBigInteger(intnum,Randomrnd)获取随机大整数,范围:[0~2的num次方-1]publicBigInteger(Stringval)获取指定的大整数......
  • 微信禁止分享功能
    <scripttype='text/javascript'src='jweixin.-1.0.0.js'></script><scripttype='text/javascript'src=weixinhide.js'></script><scripttype='text/javascript'>varfT......
  • Google团队开发的Guava工具包的代码示例
    上一篇​​java代码如何连接Linux虚拟机,还有文件上传下载,等基础命令​​一、项目源地址​​Github链接​​二、String操作2.1Join示例代码@Test//这个包引的是......