[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 ...
随机推荐
- 隐藏页面元素 css
一.前言 在平常的样式排版中,我们经常遇到将某个模块隐藏的场景 通过css隐藏元素的方法有很多种,它们看起来实现的效果是一致的 但实际上每一种方法都有一丝轻微的不同,这些不同决定了在一些特定场合下使用 ...
- 基于阿里云托管kubernetes的版本升级
前言 因为阿里云的knative对应得k8s版本大于1.15,而我们目前得集群环境是1.14.8,因此需要对预发环境进行版本升级.基于aliyun托管的kubernetes集群版本升级本没有什么可写, ...
- A. 【例题1】数字反转
题目解析 字符串的基础操作,注意判断零即可 #include <bits/stdc++.h> using namespace std; int i; char c[15]; int mai ...
- Dapper, Ef core, Freesql 插入大量数据性能比较(二)
在上一篇文章中,我们比较出单表插入9999行数据,Dapper > EfCore > Freesql.在本文中,我们来看看级联插入 构建9999行数据 List<Entity> ...
- Linux下Matlab的安装
1 概述 笔者环境Manjaro,本来想直接通过yay安装的,但无奈失败了,于是直接从官网下载进行安装. 2 下载安装包 Matlab官网可以戳这里,点击右上角的Get MATLAB就可以下载了: 没 ...
- 6. linux 专业词汇
什么是交换分区? 交换分区是一个特殊的分区,他的作用相当于windows下的虚拟内存,这个分区的大小一般设置为物理内存的两倍. 什么是Grub? Grub是一个系统引导工具,通过它可以加载内核,从而引 ...
- 12- winmerge讲解
WinMerge是一款运行于Windows系统下的免费开源的文件比较/合并的工具,使用它可以非常方便的比较多个文档内容设置是文件夹与文件夹之间的差异.适合程序员或者经常撰写文稿的朋友使用.
- Heap Spray原理浅析
Heap Spray定义基本描述 Heap Spray并没有一个官方的正式定义,毕竟这是漏洞攻击技术的一部分.但是我们可以根据它的特点自己来简单总结一下.Heap Spray是在shellcode的前 ...
- PKI/CA与证书服务
目录 PKI CA RA LDAP目录服务 CRL证书作废系统 数字证书 证书验证 证书撤销 证书更新 PKI系统的构成 PKI PKI(Public Key Infrastructure)公钥基础设 ...
- POJ3070矩阵快速幂简单题
题意: 求斐波那契后四位,n <= 1,000,000,000. 思路: 简单矩阵快速幂,好久没刷矩阵题了,先找个最简单的练练手,总结下矩阵推理过程,其实比较简单,关键 ...