最近無聊,想玩玩微信的公衆平臺,後來發現樂趣無窮啊~python
使用的工具,python 新浪SAE平臺,微信的公衆平臺mysql
你須要先在微信的公衆平臺與新浪SAE平臺上各類註冊,微信平臺註冊的時候須要你拍張手持身份證的照片,還有幾天的審覈期web
微信公衆平臺:http://mp.weixin.qq.com算法
新浪SAE:http://sae.sina.com.cn/sql
等待微信公衆審覈經過後,登陸公衆平臺後,點擊高級功能。將會看到須要提供一個接入信息:json
微信接口配置api
那麼咱們須要一個網址做爲接口(這時就須要SAE上搭建Python的一個應用),Token呢,就是至關於咱們和微信之間約定的「密碼」,這裏能夠隨便填寫英文或者數字,但實測輸入純數字有時會有問題,因此仍是字符串比較靠譜。服務器
第一步,在SAE上搭建python的應用,在下圖的應用裏選擇python應用。微信
填好二級域名和應用名稱等,選擇好語言。這裏咱們使用Python開發選擇web應用。建立好應用以後,在代碼管理中建立一個新的版本。然後咱們能夠選擇編輯代碼。可以實如今線編輯,根本用不着配置本地環境,SVN等等。固然像這種輕量級的應用在線編輯器就能夠了,SVN的話還不如在線編輯好用app
第二步,編寫index.wsgi
由於咱們使用的是web.py框架,由於其良好的xml解析,想了解web.py的童鞋能夠移步 http://webpy.org/docs/0.3/tutorial.zh-cn
首先編寫config.yaml
name: yangyanxing version: 1 libraries: - name: webpy version: "0.36" - name: lxml version: "2.3.4" ...
注意嚴格的縮進,差一個空格你就廢了!並且調試的時候很很差發現問題。。。
接着咱們繼續編寫index.wsgi
# coding: UTF-8 import os import sae import web from weixinInterface import WeixinInterface urls = ( '/weixin','WeixinInterface' ) app_root = os.path.dirname(__file__) templates_root = os.path.join(app_root, 'templates') render = web.template.render(templates_root) app = web.application(urls, globals()).wsgifunc() application = sae.create_wsgi_app(app)
簡單解釋一下,
from weixinInterface import WeixinInterface
這裏咱們須要再建立一個weixinInterface的py文件,你也能夠將這個類寫在index.wsgi文件中,只是這樣看起來會亂亂的
新建一個weixinInterface.py文件,注意大小寫,寫入如下代碼
# -*- coding: utf-8 -*- import hashlib import web import lxml import time import os import urllib2,json from lxml import etree class WeixinInterface: def __init__(self): self.app_root = os.path.dirname(__file__) self.templates_root = os.path.join(self.app_root, 'templates') self.render = web.template.render(self.templates_root) def GET(self): #獲取輸入參數 data = web.input() signature=data.signature timestamp=data.timestamp nonce=data.nonce echostr=data.echostr #本身的token token="yangyanxing" #這裏改寫你在微信公衆平臺裏輸入的token #字典序排序 list=[token,timestamp,nonce] list.sort() sha1=hashlib.sha1() map(sha1.update,list) hashcode=sha1.hexdigest() #sha1加密算法 #若是是來自微信的請求,則回覆echostr if hashcode == signature: return echostr
這裏定義了一個GET方法,是根據微信公衆平臺的要求,進行的token驗證,由於這裏咱們定義了templates_root爲根目錄下的templates,因此還要在根目錄下建立一個目錄templates的目錄
1 | 開發者經過檢驗signature對請求進行校驗(下面有校驗方式)。若確認這次GET請求來自微信服務器,請原樣返回echostr參數內容,則接入生效,不然接入失敗。 |
2 |
3 | signature結合了開發者填寫的token參數和請求中的timestamp參數、nonce參數。 |
4 |
5 | 加密/校驗流程: |
6 | 1. 將token、timestamp、nonce三個參數進行字典序排序 |
7 | 2. 將三個參數字符串拼接成一個字符串進行sha1加密 |
8 | 3. 開發者得到加密後的字符串可與signature對比,標識該請求來源於微信 |
由於微信是將驗證信息GET發出去的,因此這裏使用了GET方法來取得值而且返回相應用值
保存所有,如今回到微信的公衆平臺高級管理界面
在url裏面填寫你在新浪SAE裏應用名稱而且加上/weixin,如:http://XXXX.sinaapp.com/weixin token隨便輸入,只要注意更改weixinInterface.py中的token就好了,輸入好了之後點擊提交,若是沒有什麼問題的話就會經過驗證!
第三步,新建一個簡單的自動回覆的方法,鸚鵡學舌,就是用戶說什麼,它也回覆什麼,沒什麼用,只是隨便玩玩!
在weixinInterface.py裏繼續添加代碼
def POST(self): str_xml = web.data() #得到post來的數據 xml = etree.fromstring(str_xml)#進行XML解析 content=xml.find("Content").text#得到用戶所輸入的內容 msgType=xml.find("MsgType").text fromUser=xml.find("FromUserName").text toUser=xml.find("ToUserName").text return self.render.reply_text(fromUser,toUser,int(time.time()),u"我如今還在開發中,尚未什麼功能,您剛纔說的是:"+content)
這個def 是和上一個GET同級的,注意縮進
接着咱們在templates目錄下建立reply_text.xml模板文件,寫入如下代碼
$def with (toUser,fromUser,createTime,content) <xml> <ToUserName><![CDATA[$toUser]]></ToUserName> <FromUserName><![CDATA[$fromUser]]></FromUserName> <CreateTime>$createTime</CreateTime> <MsgType><![CDATA[text]]></MsgType> <Content><![CDATA[$content]]></Content> </xml>
注意這裏的toUser與fromUser是剛纔post的是相反的,由於這裏的toUser也就是POST函數裏的fromUser,這裏的fromUser也就是POST函數裏的toUser,msgType是text
所有保存,如今就在用你的我的微信關注一下你建立的公衆微信號,而後隨便輸入些內容,若是沒有什麼問題,你將會收到一條鸚鵡學舌的回覆內容!
接下來,咱們利用有道的翻譯api作一個翻譯的小工具
使用python一步一步搭建微信公衆平臺(二)----搭建一箇中英互譯的翻譯工具
使用python一步一步搭建微信公衆平臺(三)----添加用戶關注後的歡迎信息與聽音樂功能
使用python一步一步搭建微信公衆平臺(四)----將小黃雞引入微信自動回覆
使用python一步一步搭建微信公衆平臺(五)----使用mysql服務來記錄用戶的反饋