大佬教程收集整理的这篇文章主要介绍了使用beego快速开发微信公众平台(一),大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
微信公众平台的开发,说穿了一文不值,因为公众平台存在的目的就是给人用的,不存在什么技术门槛,但过程中坑实在太多,记录下来,希望能帮到其他人吧。
在基本配置菜单中,可以看到修改配置按钮(群里真有找不到的),点进去
如果服务器已经通过Nginx等方式将地址映射到了80端口,可以像这么写(Token和Key当然已经换掉了)
在文档中,官方是这么写的:将这3个参数按照字典序排序,刚开始我是懵逼的,后来发现就是各语言版本的sort…接下来就好说了
我们加个路由,这个地址就是填入服务器配置中的url
接着在controllers中添加WxConnect.go文件
package controllers
import (
"github.com/astaxie/beego"
"Strings"
"sort"
"crypto/sha1"
"io"
"fmt"
)
type WxConnectController struct {
beego.Controller
}
const Token = "Dswq1322s1dfsf31s2af321231rew"
func (c *WxConnectController) Get() {
//微信接入验证 这是首次对接微信 填写url后 微信服务器会发一个请求过来
//c.Ctx.request.URL-------------wx_connect?signature=038d75ed5485b9881a01b3b93e85f9fff28ea739&echostr=5756456183388806654×tamp=1476173150&nonce=1093541731
//开发者提交信息(包括URL、Token)后,微信服务器将发送http Get请求到填写的URL上,
//GET请求携带四个参数:signature、timestamp、nonce和echostr。公众号服务程序应该按如下要求进行接入验证
timestamp,nonce,signatureIn := c.GetString("timestamp"),c.GetString("nonce"),c.GetString("signature")
signatureGen := makeSignature(timestamp,noncE)
//将加密后获得的字符串与signature对比,如果一致,说明该请求来源于微信
if signatureGen != signatureIn {
fmt.Printf("signatureGen != signatureIn signatureGen=%s,signatureIn=%s\n",signatureGen,signatureIn)
c.Ctx.WriteString("")
} else {
//如果请求来自于微信,则原样返回echostr参数内容 以上完成后,接入验证就会生效,开发者配置提交就会成功。
echostr := c.GetString("echostr")
c.Ctx.WriteString(echostr)
}
}
func makeSignature(timestamp,nonce String) String {
//1. 将 plat_token、timestamp、nonce三个参数进行字典序排序
sl := []String{Token,timestamp,noncE}
sort.Strings(sl)
//2. 将三个参数字符串拼接成一个字符串进行sha1加密
s := sha1.New()
io.WriteString(s,Strings.Join(sl,""))
return fmt.Sprintf("%x",s.Sum(nil))
}
重新跑一下项目,点击设置页面上的提交按钮,应该就能显示通过,请仔细校对参数,复制粘贴犹佳。 至此,微信公众平台已经向你敞开了大门(记得点启用按钮,否则光验证通过没什么卵用)。
以上是大佬教程为你收集整理的使用beego快速开发微信公众平台(一)全部内容,希望文章能够帮你解决使用beego快速开发微信公众平台(一)所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。