写在前面
《使用Python进行微信公众号开发》系列文章将与大家分享如何使用Python一步步搭建微信公众号后台服务器。
效果体验
扫码“是雯子吖”公众号进行体验
配置自己的公众号后台进行体验
想要体验效果的小伙伴可以将微信公众号后台的 开发-> 基本配置 -> 服务器配置 中的Token随意配置,服务器地址配置为 https://apit.toodo.fun/wechatMP/ + Token,如
Token = hello # 可随意设置,但是要保证与服务器地址最后一项相同
服务器地址:https://apit.toodo.fun/wechatMP/hello
消息加解密方式:明文模式或者兼容模式
如果配置成功的话,新关注你公众号的用户将会收到“Hi~ 终于等到你”,并且收到消息后会由我服务器上的机器人自动回复。
后台服务器搭建
我们选择flask进行服务器后台开发,在这一步中,会与大家分享微信公众号与服务器对接流程。
接收参数
在微信公众号第一次与服务器进行对接时,将向填写的服务器URL发送一个GET请求,GET请求携带的参数如下:
参数 | 描述 |
---|---|
signature | 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。 |
timestamp | 时间戳 |
nonce | 随机数 |
echostr | 随机字符串(仅第一次服务器验证时有此参数) |
代码片段
@app.route('/')
def main():
signature = request.values.get('signature')
timestamp = request.values.get('timestamp')
nonce = request.values.get('nonce')
echostr = request.values.get('echostr')
signature校检
当接收到参数后,我们需要确认这条消息是否来自微信服务器,即signature校检。
校检流程如下:
- 将token、timestamp、nonce三个参数进行字典序排序
- 将排序后的三个参数拼接为一个字符串,然后进行sha1加密
- 将加密后的字符串与参数中的signature参数进行对比,如果相同则通过校检,否则则不通过校检
代码片段
def checkSignature(token, timestamp, nonce, signature):
temp = [token, timestamp, nonce]
temp.sort()
res = hashlib.sha1("".join(temp).encode('utf8')).hexdigest()
return True if res == signature else False
微信公众号与服务器对接
在微信公众号向服务器发送的第一次请求中包含echostr参数,在对接过程中仅需要返回这一参数即可。
代码片段
if echostr:
return echostr
本小节代码汇总
from flask import Flask, request, abort
import hashlib
app = Flask(__name__)
@app.before_request
def checkSignature():
signature = request.values.get('signature')
timestamp = request.values.get('timestamp')
nonce = request.values.get('nonce')
echostr = request.values.get('echostr') # 仅在验证服务器时使用次参数
if not wmp.checkSignature(timestamp=timestamp, nonce=nonce, signature=signature):
abort(404)
if echostr:
return echostr
@app.route('/')
def main():
return "是雯子吖"
if __name__ == '__main__':
app.run()
未完待续
参考文档
开发者文档-接入指南:https://developers.weixin.qq.com/doc/offiaccount/Basic_Information/Access_Overview.html