程序可以實現很多美好的事情,如果有好的Idea,微信開發實現的功能完全可以替代電腦程序或手機APP。
偶然聽同事聊天,說關注了某一電影資源微信公眾號,只需在對話框回復電影名稱,對方公眾號便可直接推送這部電影的下載鏈接。
我便梳理了一下這個流程,這就相當于將電影網站的搜索框的功能,移植到了微信公眾平臺上面了。具體的實現思路應該是:
- 利用微信提供的接口,獲取用戶發送的消息
- 處理用戶發來的消息,通過在事先準備好的數據庫中匹配到對應的電影資源
- 再次通過消息回復接口發送給用戶
上面第二部功能部分就不講了,本文主要介紹對接微信公眾平臺的消息接口,然后實現簡單消息自動回復的功能。
開發前的準備
需要準備兩個東西:申請好的微信訂閱號和一臺云服務器。目前市面上為大家所熟知的云服務器包括:阿里云、新浪SAE和騰訊云。因為本人很早便申請了新浪云的服務器,所以本文是基于在SAE上測試的。
如果你需要申請SAE,可以使用我的專屬推薦鏈接:http://t.cn/R5p4gRu,如果申請成功,對于我們兩人都會有獎勵。
另外:本文使用Python的Flask來開發。
新浪SAE的配置
因為微信后臺配置時,需要驗證自己事先設置好的服務器,所以這里先簡單介紹一下新浪SAE的配置,和簡單的微信驗證代碼。
進入自己的新浪云后臺,選擇創建新應用,然后開發語言選擇Python,運行環境選擇標準環境,填寫自己唯一想要的二級域名和自己的應用名稱,之后點擊右邊的創建應用按鈕,即可創建成功。
下圖為我已經創建好的應用:
之后便可以使用Git在自己電腦上編輯好代碼,然后傳至自己已經申請好的云應用中。
Git代碼部署說明
在你應用的git代碼目錄里,添加一個新的git遠程倉庫 sae
$ git remote add sae https://git.sinacloud.com/jikenow
編輯代碼并將代碼部署到 sae
的版本1。
$ git add .
$ git commit -m 'Init my first app'
$ git push sae master:1
SAE支持Git、SVN、代碼打包上傳三種提交方式,具體請參考:http://www.sinacloud.com/doc/sae/tutorial/code-deploy.html#git
下面我給出的代碼,也是通過以上git
方法傳到云應用中,如果不是很清楚,可以閱讀上面給出的幫助文檔。
微信驗證代碼
當在微信后臺配置自己的云服務器時,微信的服務器會發送GET請求至我們提供的URL,這時需要我們通過一些判斷來確認其確實是由微信發起的請求,如果確認ok,就返還給微信echostr參數內容
。具體Python-Flask代碼如下:
#coding:utf-8
from flask import Flask,request,make_response
import time,hashlib,re,requests
import xml.etree.ElementTree as ET
app = Flask(__name__)
@app.route('/weixin',methods = ['GET','POST'])
def weixin():
# 微信驗證
if request.method == 'GET':
token = 'weixin'
query = request.args
signature = query.get('signature','')
timestamp = query.get('timestamp','')
nonce = query.get('nonce','')
echostr = query.get('echostr','')
s = [timestamp,nonce,token]
s.sort()
s = ''.join(s)
if hashlib.sha1(s).hexdigest() == signature:
return make_response(echostr)
注意我上面路由設置的是/weixin
后綴,所以我之后向微信后臺添加的配置URL就是http://jikenow.applinzi.com/weixin
,前面的網址便是我申請的二級域名。
參考網址:微信接入指南
附邏輯流程圖:
寫好了之后保存為main.py
,然后還需要新建一個index.wsgi
的文件,是SAE要用到,文件內容如下:
import sae
from main import app
application = sae.create_wsgi_app(app)
保存好之后,將以上兩個文件通過Git
傳至云應用中。
微信公眾平臺后臺開發者配置
- 進入微信公眾平臺后臺,選擇開發選項下的基本配置
- 之后可以看到服務器配置選項,點擊修改配置
- 填寫對應的服務器URL(http://jikenow.applinzi.com/weixin)和Token參數(本人用的是weixin,你可以設置自己唯一的字符),為了方便開發,加解密方式設置為明文模式,提交
- 此時微信便會發送GET請求至我們的服務器URL中,我們之前已設置好,所以應該會通過驗證
- 點擊啟用即可成功
下圖顯示已啟用(驗證成功):
重頭戲:被動回復用戶消息
上面說了一大堆,只是一些準備工作而已,如果上面的準備工作有所不明白的,你可以參考我在文章末給出的幾個鏈接文章。
回歸正題,現在需要編寫一個很簡單的小程序,模仿用戶說話,也就是用戶向你發送什么文本內容,你原樣返回給用戶此文本內容即可。
流程有下面三點:
- 接收用戶發送的普通文本消息,微信會通過POST方式將XML數據包發送給我們的URL中
- 復制此文本消息且生成回復的XML格式的數據
- 被動消息回復給微信服務器,然后即發送給用戶
上面三點的邏輯清楚了,代碼也就不難理解了,接著上面的微信驗證代碼來:
def weixin():
# 微信驗證
# 上面給出
# 被動回復消息
else: # 即如果為POST請求執行下面的代碼
xmlData = ET.fromstring(request.stream.read())
msg_type = xmlData.find('MsgType').text
if msg_type == 'text':
ToUserName = xmlData.find('ToUserName').text
FromUserName = xmlData.find('FromUserName').text
Content = xmlData.find('Content').text
reply = '''<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[%s]]></Content>
</xml>'''
response = make_response( reply % (FromUserName, ToUserName, str(int(time.time())), Content ) )
response.content_type = 'application/xml'
return response
搞好之后,保存main.py
文件,上傳至服務器。至此,我們的微信模仿用戶說話的小功能已經做好了。
功能雖小,但是已經邁出了第一步,之后的所有更強大的功能,都會在此基礎上延伸。