[Python] 微信公众号开发 Python3
搭建服务
- 开通一个阿里云ecs,安装python3及需要的包(参考下方官方文档)
- 将py文件保存在ecs上,运行
- 在本地访问阿里云的IP地址
- 能完成这步说明网络没问题
server.py

1 # -*- coding: utf-8 -*-
2 # filename: server.py
3 import web
4
5 urls = (
6 '/wx', 'Handle',
7 )
8
9 class Handle(object):
10 def GET(self):
11 return "hello, this is handle view"
12
13 if __name__ == '__main__':
14 app = web.application(urls, globals())
15 app.run()

公众号配置
- 注册公众号
- 验证token
- 官方文档是python2写的,不能直接用,python3代码如下
server.py

1 # -*- coding: utf-8 -*-
2 # filename: main.py
3 import web
4 from handle import Handle
5
6 urls = (
7 '/wx', 'Handle',
8 )
9
10 if __name__ == '__main__':
11 app = web.application(urls, globals())
12 app.run()
handle.py

1 import hashlib
2 import web
3
4 class Handle(object):
5 def GET(self):
6 try:
7 data = web.input()
8 if len(data) == 0:
9 return "hello,this is handle view"
10 signature = data.signature
11 timestamp = data.timestamp
12 nonce = data.nonce
13 echostr = data.echostr
14 token = "hfxlcxc"
15
16 list = [token, timestamp, nonce]
17 list.sort()
18 sha1 = hashlib.sha1()
19 sha1.update(list[0].encode('utf-8'))
20 sha1.update(list[1].encode('utf-8'))
21 sha1.update(list[2].encode('utf-8'))
22 hashcode = sha1.hexdigest()
23
24 print("handle/GET func:hashcode, signature: ", hashcode, signature)
25 if hashcode == signature:
26 return echostr
27 else:
28 return ""
29 except (Exception,Argument):
30 return Argument

自动回复
- 调试接口
- 官方文档python里的xml中间有空格,虽然调试可以通过,但在微信里发消息不会自动回复
server.py

1 # -*- coding: utf-8 -*-
2 # filename: server.py
3 import web
4 from handle import Handle
5
6 urls = (
7 '/wx', 'Handle',
8 )
9
10 if __name__ == '__main__':
11 app = web.application(urls, globals())
12 app.run()
handle.py

1 # -*- coding: utf-8 -*-#
2 # filename: handle.py
3
4 import hashlib
5 import web
6 import receive
7 import reply
8
9 class Handle(object):
10 def POST(self):
11 try:
12 webData = web.data()
13 print("Handle Post webdata is ",webData)
14 # 后台打印日志
15 recMsg = receive.parse_xml(webData)
16 if isinstance(recMsg, receive.Msg) and recMsg.MsgType == 'text':
17 toUser = recMsg.FromUserName
18 fromUser = recMsg.ToUserName
19 content = "test!!"
20 replyMsg = reply.TextMsg(toUser, fromUser, content)
21 return replyMsg.send()
22 else:
23 print("暂不处理")
24 return "success"
25 except (Exception,Argment):
26 return Argment
receive.py

1 # -*- coding: utf-8 -*-#
2 # filename: receive.py
3
4 import xml.etree.ElementTree as ET
5
6 def parse_xml(web_data):
7 if len(web_data) == 0:
8 return None
9 xmlData = ET.fromstring(web_data)
10 msg_type = xmlData.find('MsgType').text
11 if msg_type == 'text':
12 return TextMsg(xmlData)
13 elif msg_type == 'image':
14 return ImageMsg(xmlData)
15
16 class Msg(object):
17 def __init__(self,xmlData):
18 self.ToUserName = xmlData.find('ToUserName').text
19 self.FromUserName = xmlData.find('FromUserName').text
20 self.CreateTime = xmlData.find('CreateTime').text
21 self.MsgType = xmlData.find('MsgType').text
22 self.MsgId = xmlData.find('MsgId').text
23
24 class TextMsg(Msg):
25 def __init__(self,xmlData):
26 Msg.__init__(self,xmlData)
27 self.Content = xmlData.find('Content').text.encode("utf-8")
28
29 class ImageMsg(Msg):
30 def __init__(self, xmlData):
31 Msg.__init__(self,xmlData)
32 self.PicUrl = xmlData.find('PicUrl').text
33 self.MediaId = xmlData.find('MediaId').text
reply.py

1 # -*- coding: utf-8 -*-#
2 # filename: reply.py
3 import time
4
5 class Msg(object):
6 def __init__(self):
7 pass
8
9 def send(self):
10 return "success"
11
12 class TextMsg(Msg):
13 def __init__(self, toUserName, fromUserName, content):
14 self.__dict = dict()
15 self.__dict['ToUserName'] = toUserName
16 self.__dict['FromUserName'] = fromUserName
17 self.__dict['CreateTime'] = int(time.time())
18 self.__dict['Content'] = content
19
20 def send(self):
21 XmlForm = """<xml><ToUserName><![CDATA[{ToUserName}]]></ToUserName><FromUserName><![CDATA[{FromUserName}]]></FromUserName><CreateTime>{CreateTime}</CreateTime><MsgType><![CDATA[text]]></MsgType><Content><![CDATA[{Content}]]></Content></xml>"""
22 return XmlForm.format(**self.__dict)
23
24 class ImageMsg(Msg):
25 def __init__(self, toUserName, fromUserName, mediaId):
26 self.__dict = dict()
27 self.__dict['ToUserName'] = toUserName
28 self.__dict['FromUserName'] = fromUserName
29 self.__dict['CreateTime'] = int(time.time())
30 self.__dict['MediaId'] = mediaId
31
32 def send(self):
33 XmlForm = """<xml><ToUserName><![CDATA[{ToUserName}]]></ToUserName><FromUserName><![CDATA[{FromUserName}]]></FromUserName><CreateTime>{CreateTime}</CreateTime><MsgType><![CDATA[image]]></MsgType><Image><MediaId><![CDATA[{MediaId}]]></MediaId></Image></xml>"""
34 return XmlForm.format(**self.__dict)


参考
官方文档
https://developers.weixin.qq.com/doc/offiaccount/Getting_Started/Getting_Started_Guide.html
w3c教程
https://www.w3cschool.cn/weixinkaifawendang/
token验证失败
https://www.cnblogs.com/roadwide/p/10566946.html
https://blog.csdn.net/qq_39866513/article/details/83218731
获取access token
https://blog.csdn.net/wchenjt/article/details/96154504
https://blog.csdn.net/qq_26626113/article/details/78251932
白名单
https://cloud.tencent.com/developer/article/1034608
接口调试
https://www.cnblogs.com/txw1958/p/mp-weixin-debug.html
自动回复失败
http://www.alixixi.com/biancheng/a/2019022498588.shtml
[Python] 微信公众号开发 Python3的更多相关文章
- Python微信公众号开发—小白篇
本文面向想通过Python学习公众号开发的同学.一站式解决新手开发微信公众号遇到的所有问题. 为了防止我的文章被到处转载,贴一下我的公众号[智能制造专栏],欢迎大家关注. github仓库地址http ...
- Python微信公众号开发—小白篇(1)
本文面向想通过Python学习公众号开发的同学.一站式解决新手开发微信公众号遇到的所有问题. 为了防止我的文章被到处转载,贴一下我的公众号[智能制造社区],欢迎大家关注. github仓库地址http ...
- Python微信公众号开发
最近老大叫我学习开发微信,试着玩了下.网上查了下文档.有点过时. 简单步骤: 1)申请服务器并完成环境配置 去腾讯云购买云服务器.当然你也可以购买其他产品,比如阿里云.因为我是学生,有优惠110一年. ...
- python微信公众号开发学习记录
网上有很多微信公众号的开发教程,但是都是好几年前的了,而且很多都是抄袭其他人的,内容几乎一模一样.真的无语了.只好自己总结一下开发的一些简单流程. 一先去注册个微信公众号,这个就不详细说了, 二登录后 ...
- python之微信公众号开发(基本配置和校验)
前言 最近有微信公众号开发的业务,以前没有用python做过微信公众号开发,记录一下自己的学习和开发历程,共勉! 公众号类型 订阅号 普通订阅号 认证订阅号 服务号 普通服务号 认证服务号 服务方式 ...
- Python微信公众号教程基础篇——收发文本消息
1. 概述: 在本篇教程中,你将学会使用华为云弹性云服务器(以下简称 ECS)搭建微信公众号处理后台,使用Python语言编写对应的微信消息处理逻辑代码,接收从微信服务端转发过来的消息,并返回处理结果 ...
- 微信公众号开发被动回复用户消息,回复内容Content使用了"\n"换行符还是没有换行
使用语言和框架:本人后端开发使用的Python的DRF(Django REST framework)框架 需求:在微信公众号开发时,需要实现自动回复,即被关注回复.收到消息回复.关键词回复 发现问题: ...
- 微信公众号开发(一)--验证服务器地址的Java实现
现在主流上都用php写微信公众号后台,其实作为后端语言之一的java也可以实现. 这篇文章将对验证服务器地址这一步做出实现. 参考资料:1.慕课网-<初识java微信公众号开发>,2.微信 ...
- C#微信公众号开发系列教程三(消息体签名及加解密)
http://www.cnblogs.com/zskbll/p/4139039.html C#微信公众号开发系列教程一(调试环境部署) C#微信公众号开发系列教程一(调试环境部署续:vs远程调试) C ...
随机推荐
- istio: 无法提供内部访问外部服务
现象 能够内部无法访问外部服务. 在部署测试服务 kubectl apply -f samples/sleep/sleep.yaml 设置环境变量 export SOURCE_POD=$(kubect ...
- [Fundamental of Power Electronics]-PART II-8. 变换器传递函数-8.2 变换器传递函数分析
8.2 变换器传递函数分析 接下来,让我们推导基本变换器传递函数中的极点,零点和渐近线增益的解析表达式. 8.2.1 示例:Buck-boost变换器的传递函数 Buck-boost变换器的小信号等效 ...
- Dynamics CRM绑定表单查看当前表单的数据参数传递
我们做报表的时候,报表运行的位置可以在列表.也可以在报表区同时也可以在表单界面 其他两个都还好,不需要进行过滤,但是在表单界面运行报表需要将表单的GUID传给报表获取数据,否则就得手动去输入ID 具体 ...
- 两种纯CSS方式实现hover图片pop-out弹出效果
实现原理 主要图形的组成元素由背景和前景图两个元素,以下示例代码中,背景元素使用伪元素 figure::before 表示, 前景元素使用 figure img 表示,当鼠标 hover 悬浮至 fi ...
- NumPy之:NumPy简介教程
目录 简介 安装NumPy Array和List 创建Array Array操作 sort concatenate 统计信息 reshape 增加维度 index和切片 从现有数据中创建Array 算 ...
- JAVAEE_Servlet_24_HttpSession实现原理
关于JavaWeb中的HttpSession (一) * Session表示会话,不止存在于JavaWeb之中,只要是Web开发都会存在这种机制 * Session包:javax.servlet.ht ...
- 1079 Total Sales of Supply Chain
A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)-- everyone invo ...
- mysql 密码忘记解决办法
bin>net stop mysql bin>mysqld --skip-grant-tables bin>mysql mysql>use mysql mysql>upd ...
- 缓冲区溢出分析第10课:Winamp缓冲区溢出研究
前言 Winamp是一款非常经典的音乐播放软件,它于上世纪九十年代后期问世.与现在音乐播放软件行业百家争鸣的情况不同,当时可以说Winamp就是听音乐的唯一选择了,相信那个时代的电脑玩家是深有体会的. ...
- drozer源码学习二:info+scanner
Information: datetime: 输出android中当前日期:time. setToNow() deviceinfo: 输出设备信息 deviceinfo做了三件事: 1. ...