同步操作将从 jeff kit/wechat 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
作者: @jeff_kit
本SDK支持微信公众号以及企业号的上行消息及OAuth接口。本文档及SDK假设使用者已经具备微信公众号开发的基础知识,及有能力通过微信公众号、企业号的文档来查找相关的接口详情。
pip install wechat
git clone git@github.com:jeffkit/wechat.git
cd wechat
python setup.py install
对于微信用户在公众号内发送的上行消息,本sdk提供了一个微型处理框架,开发者只需继承wechat.official.WxApplication类, 实现各种消息对应的方法,然后把该类与自己熟悉的web框架结合起来使用即可。
WxApplication内部会实现请求的合法性校验以及消息的分发等功能,还对上行消息对行了结构化,开发者把精力放到业务逻辑的编写即可。
WxApplication类核心方法:
WxApplication的process函数,接受以下参数:
process最后返回一串文本(xml或echoStr)。
在微信公众号的后台设置好URL及token等相关信息后,微信会通过GET的方式访问一次该URL,开发者在URL的响应程序里直接调用app.process(params, xml=None)即可返回echStr。
qs = 'nonce=1221&signature=19selKDJF×tamp=12312'
query = dict([q.split('=') for q in qs.split('&')])
app = YourApplication()
echo_str = app.process(query, xml=None)
# 返回echo_str给微信即可
用户在微信公众号上发消息给公众号,微信服务器调用上行的URL,开发者需要对每次的的请求进行合法性校验及对消息进行处理,同样的,直接调用app.process方法就好。
qs = 'nonce=1221&signature=19selKDJF×tamp=12312'
query = dict([q.split('=') for q in qs.split('&')])
body = '<xml> ..... </xml>'
app = YourApplication()
result = app.process(query, xml=body)
# 返回result给微信即可
下面先看看一个WxApplication的示例代码,用于把用户上行的文本返还给用户:
from wechat.official import WxApplication, WxTextResponse, WxMusic,\
WxMusicResponse
class WxApp(WxApplication):
SECRET_TOKEN = 'test_token'
WECHAT_APPID = 'wx1234556'
WECHAT_APPSECRET = 'sevcs0j'
def on_text(self, text):
return WxTextResponse(text.Content, text)
需要配置几个类参数,几个参数均可在公众号管理后台的开发者相关页面找到,前三个参数如果不配置,则需要在调用process方法时传入。
然后,您需要逐一实现WxApplication的各个on_xxxx函数。不同类型的上行消息及事件均有对应的on_xxx函数
所有的on_xxx函数列举如下:
on_xxx函数的定义如下:
def on_xxx(self, req):
return WxResponse()
on_xxx函数,接受一个WxRequest参数req,返回一个WxResponse的子类实例。
req是一个代表用户上行消息的WxRequest实例。其属性与消息的XML属性一一对应,不同的消息有几个相同的属性:
不同的消息类型对应有各自的属性,属性名与消息的xml标签名保一致。如MsgType为text的的req,有一个Content属怀,而MsgType为image的req,则有PicUrl及MediaId两个属性。更多消息详情请查看微信公众号官方文档。
on_xxx函数需要返回一个WxResponse的子类实例。WxResponse的子类及其构造的方式有:
WxTextResponse("hello", req)
WxImageResponse(WxImage(MediaId='xxyy'),req)
WxVoiceResponse(WxVoice(MediaId='xxyy'),req)
WxVideoResponse(WxVideo(MediaId='xxyy', Title='video', Description='test'),req)
WxMusicResponse(WxMusic(Title='hey jude',
Description='dont make it bad',
PicUrl='http://heyjude.com/logo.png',
Url='http://heyjude.com/mucis.mp3'), req)
WxNewsResponse(WxArticle(Title='test news',
Description='this is a test',
Picurl='http://smpic.com/pic.jpg',
Url='http://github.com/jeffkit'), req)
WxEmptyResponse(req)
下面以Django为例说明,实现一个微信回调的功能(view),利用上面示例代码中的WxApp:
from django.http import HttpResponse
def wechat(request):
app = WxApp()
result = app.process(request.GET, request.body)
return HttpResponse(result)
配置 urls.py:
urlpatterns = patterns('',
url(r'^wechat/', 'myapp.views.wechat'),
)
from flask import request
from flask import Flask
app = Flask(__name__)
@app.route('/wechat')
def wechat():
app = WxApp()
return app.process(request.args, request.data)
OK.就这么多,WxApplication本身与web框架无关,不管你使用哪个Framework都可以享受到它带来的便利。
好吧,其实,你可以在任何地方写on_xxx的响应函数。然后在使用之前,告诉一个WxApplication你要用哪个函数来响应对应的事件就好。以Django为例:
# 在任何地方写你自己的消息处理函数。
# @any_decorator # 添加任何装饰器。
def my_text_handler(req):
return WxTextResponse(req.Content, req)
# 在web的程序里这样使用:
def wechat_view(request):
app = WxApplication() # 实例化基类就好。
app.handlers = {'text': my_text_handler} # 设置你自己的处理器
result = app.process(request.GET, request.body,
token='xxxx', app_id='xxxx', aes_key='xxxx')
return HttpResponse(result)
嗯,可以自定义消息的handlers,而如果要针对事件自定义handlers的话,要修改app.event_handlers,数据的格式是一样的。具体的消息和事件类型的key,就直接看看源码得了。卡卡。
OAuth API目前仅支持下列常用接口:
其他接口拟于未来的版本中支持,同时欢迎大家来增补。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。