golang开发微信公众号(使用测试号)
<ul><li>
<h2 id="golang开发微信公众号使用测试号">golang开发微信公众号(使用测试号)</h2>
<ul>
<li>
<h3 id="开始开发之前的准备工作">开始开发之前的准备工作</h3>
<ul>
<li>
<h4 id="搞定内网穿透的问题">搞定内网穿透的问题</h4>
<ul>
<li>
<p>下载内容穿透工具:https://natapp.cn/。打开网址之后,首先注册称为会员,然后登录成功之后需要实名认证才能使用。登录成功之后,点击【购买隧道】,这里我们选择免费的隧道就可以了</p>
</li>
<li>
<p><img src="https://img2020.cnblogs.com/blog/1437248/202008/1437248-20200829125535392-99976859.png" alt="" loading="lazy"></p>
</li>
<li>
<p><img src="https://img2020.cnblogs.com/blog/1437248/202008/1437248-20200829125551751-1442400294.png" alt="" loading="lazy"></p>
</li>
<li>
<p>下载客户端</p>
</li>
<li>
<p><img src="https://img2020.cnblogs.com/blog/1437248/202008/1437248-20200829125639768-2015692685.png" alt="" loading="lazy"></p>
</li>
<li>
<p>下载完之后,解压文件,就会有一个natapp.exe(win)文件</p>
</li>
<li>
<p>使用natapp.exe -authtoken=复制已经拥有的authtoken即可,获取到一个域名</p>
</li>
<li>
<p><img src="https://img2020.cnblogs.com/blog/1437248/202008/1437248-20200829125652650-1117657414.png" alt="" loading="lazy"></p>
</li>
</ul>
</li>
<li>
<p>微信公众号测试号申请/登录:https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login</p>
</li>
<li>
<p>登录成功之后,就会看到下面的界面</p>
</li>
<li>
<p><img src="https://img2020.cnblogs.com/blog/1437248/202008/1437248-20200829125707619-1514214940.png" alt="" loading="lazy"></p>
</li>
<li>
<p>appID和appSecret,后面的很多开发都需要用到这两个参数。接口配置信息中的URL就是启动内网穿透工具后,映射我们端口的网址,Token是我们自己设置的,和接下来在代码里设置的Token一致,域名的话就是映射端口的网址去掉http协议头就行了。</p>
</li>
<li>
<p>微信平台接入验证的过程就是当我们配置好接口信息(URL和Token)提交时,微信服务器会发送一个http Get请求到我们填写的URL上,这个Get请求中附带有四个参数signature,timestamp,nonce,echostr,我们需要将我们自己设定的token和timestamp,nonce三个参数进行字典序排序(也就是按照首字母ABCD进行排序),然后将排序好的这三个参数组合成一个字符串进行sha1加密,加密后的字符串和signature进行比较(正确情况下,他们俩是一样的),如果两者相同,原样返回echostr参数给微信服务器,接入验证就成功了,我们就成为微信开发者了,就可以写各种微信功能了。(记得先开启自己的服务器,然后再点击提交)</p>
</li>
<li>
<p>golang验证代码</p>
<ul>
<li>
<pre><code class="language-go">package main
import (
"crypto/sha1"
"fmt"
"io"
"log"
"net/http"
"sort"
"strings"
)
const (
token = "sixah" //设置token
)
func makeSignature(timestamp, nonce string) string { //本地计算signature
si := []string{token, timestamp, nonce}
sort.Strings(si) //字典序排序
str := strings.Join(si, "") //组合字符串
s := sha1.New() //返回一个新的使用SHA1校验的hash.Hash接口
io.WriteString(s, str) //WriteString函数将字符串数组str中的内容写入到s中
return fmt.Sprintf("%x", s.Sum(nil))
}
func validateUrl(w http.ResponseWriter, r *http.Request) bool {
timestamp := strings.Join(r.Form["timestamp"], "")
nonce := strings.Join(r.Form["nonce"], "")
signature := strings.Join(r.Form["signature"], "")
echostr := strings.Join(r.Form["echostr"], "")
signatureGen := makeSignature(timestamp, nonce)
if signatureGen != signature {
return false
}
fmt.Fprintf(w, echostr) //原样返回eechostr给微信服务器
return true
}
func procSignature(w http.ResponseWriter, r *http.Request) {
r.ParseForm() //Request需要解析
if !validateUrl(w, r) {
log.Println("Wechat Service: This http request is not from wechat platform")
return
}
log.Println("validateUrl Ok")
}
func main() {
log.Println("Wechat Service: Start!")
http.HandleFunc("/", procSignature)
err := http.ListenAndServe(":80", nil)
if err != nil {
log.Println("Wechat Service: ListenAndServe Error: ", err)
}
log.Println("Wechat Service: Stop!")
}
</code></pre>
</li>
<li>
<p>配置成功之后,根据<strong>体验接口权限表</strong>写自己的业务代码</p>
</li>
<li>
<p>需要demo留言跟我说</p>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul><br><br>
来源:https://www.cnblogs.com/MyUniverse/p/13581884.html
頁:
[1]