網上有不少微信公衆號的開發教程,可是都是好幾年前的了,並且不少都是抄襲其餘人的,內容幾乎如出一轍。真的無語了。只好本身總結一下開發的一些簡單流程。web
一先去註冊個微信公衆號,這個就不詳細說了,flask
二登陸後臺,進入開發中的基本配置,配置下服務器後端
填寫url和token,url是服務器的地址,token是本身定義的服務器
三登陸服務器開發微信
網上不少教程用的什麼新浪sae啊,webpy都是好久以前的。如今不少東西都變了,因此我沒有用,我用的阿里的服務器以及flask作後端。app
代碼以下加密
# coding:utf-8
from hashlib import sha1 from flask import Flask, request token = 'xxxxxx' app = Flask(__name__) def get_update(token, timestamp, nonce): arguments = '' for k in sorted([token, timestamp, nonce]): arguments = arguments + str(k) m = sha1() m.update(arguments.encode('utf8')) return m.hexdigest() def check_signature(): signature = request.args.get('signature', '') timestamp = request.args.get('timestamp', '') nonce = request.args.get('nonce', '') check = get_update(token, timestamp, nonce) return True if check == signature else False def parse_xml(data): try: import xml.etree.cElementTree as ET except ImportError: import xml.etree.ElementTree as ET root = ET.fromstring(data) datas = '<xml>' for child in root: if child.tag == 'ToUserName': toUser = child.text datas += '<FromUserName>%s</FromUserName>' % toUser elif child.tag == 'FromUserName': fromUser = child.text datas += '<ToUserName>%s</ToUserName>' % fromUser else: datas += '<' + child.tag + '>' datas += child.text datas += '</' + child.tag + '>' datas += '</xml>' return datas @app.route('/weixin', methods=['GET', 'POST']) def weixinInterface(): if check_signature: if request.method == 'GET': echostr = request.args.get('echostr', '') return echostr elif request.method == 'POST': data = request.data msg = parse_xml(data) return msg else: return 'signature error' if __name__ == '__main__': app.run(host='0.0.0.0')
一開始的話微信會讓你驗證填寫的url,驗證方式是經過傳入時間戳timestamp,隨機數nonce,token事先約定好的,echostr隨機字符串,以及簽名signature,須要根據時間戳,隨機數,token的值進行字典序排序,而後用sha1加密獲得簽名,檢驗簽名是否一致,是的話返回隨機字符串echostr。若是校驗成功,就能夠提交了,提交以後就能夠啓用服務器配置。url
上面的代碼還包括了若是用戶發送信息給公衆號,返回該信息,固然只是很簡單的解析xml以及構造xml。其餘更復雜的功能須要查詢微信的文檔。spa