[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 ...
随机推荐
- CodeForces CF877D题解(BFS+STL-set)
解法\(1:\) 正常的\(bfs\)剪枝是\(\Theta(nm4k)\),这个时间复杂度是只加一个\(vis\)记录的剪枝的,只能保证每个点只进队一次,并不能做到其他的减少时间,所以理论上是过不了 ...
- ionic3+angular 倒计时效果
// 声明变量 applicationInterval: any; // 定时器 nextBtnText: String; nextBtnBool: Boolean; // 使用定时器,每秒执行一次 ...
- 翻译:《实用的Python编程》08_03_Debugging
目录 | 上一节 (8.2 日志) | 下一节 (9 包) 8.3 调试 调试建议 假设程序崩溃了: bash % python3 blah.py Traceback (most recent cal ...
- 考前自救题库NABCD分析
考前自救题库NABCD分析 项目 内容 这个作业属于哪个课程 2021春季软件工程(罗杰 任健) 这个作业的要求在哪里 团队项目-初次邂逅,需求分析 项目名称:考前自救题库(暂定) 项目简介:本产品计 ...
- 【笔记】《Redis设计与实现》chapter20 Lua脚本
chapter20 Lua脚本 Redis从2.6版本开始引入对Lua脚本的支持,通过在服务器中嵌入Lua环境,Redis客户端可以使用Lua脚本,直接在服务器端原子地执行多个Redis命令 20.1 ...
- 【2w字干货】ArrayList与LinkedList的区别以及JDK11中的底层实现
1 概述 本文主要讲述了ArrayList与LinkedList的相同以及不同之处,以及两者的底层实现(环境OpenJDK 11.0.10). 2 两者区别 在详细介绍两者的底层实现之前,先来简单看一 ...
- Dropping Balls UVA - 679
A number of K balls are dropped one by one from the root of a fully binary tree structure FBT. Eac ...
- Day09_41_集合_Set
Set集合 Set集合 - Set集合的特点是无序不可重复.Set集合类似于一个罐子,程序可以依次把多个对象"丢进"Set集合,而Set集合通常不能记住元素的添加顺序. - Set ...
- 2021 年最值得推荐的 7 个 Angular 前端组件库 - DevUI
摘要:DevUI 是一款面向企业中后台产品的开源前端解决方案,它倡导沉浸.灵活.至简的设计价值观,提倡设计者为真实的需求服务,为多数人的设计,拒绝哗众取宠.取悦眼球的设计.如果你正在开发 ToB 的工 ...
- 逻辑引擎、工作流、CMDB小感
工作流是啥? 在界面上画画点点就能生成代码,这是很吸引人的事情,也是很多自动化工具追求的目标.工作流就是这么一个东西,通过定义流程和输入,就能实现你想要的东西,不需要编写代码. 工作流的实现 通过解析 ...