今天公司老总,叫我把公司的企业微信,服务商管理后台中的本地应用进行回调验证。

听起来一脸懵逼,没搞过企业微信对接情况。一头雾水,不知道如何下手。

先讲解一下,企业微信情况。

登录到企业微信后,右上角服务商管理后台

之后点击进入应用管理界面

选择网页应用,这里说下,创建应用的方法,自己去百度一下哈,如何创建我就不阐述了。这里配置回调URL,即是你网站的URL地址,

比如:https://xxxx.xxxx.com/weixin

这里我用Django框架的公司网站进行回调验证,如果没有验证回调成功,下面会有提示需要得到服务商的响应,才可以验证成功。

接下来讲讲如何实现,微信官方给了一个Python回调验证的dome演示包,我们可以在这里下载https://work.weixin.qq.com/api/doc#90000/90138/90307/python%E5%BA%93

这里就有第一个大坑,本代码使用了pycrypto这个包,这里用到一个叫crypto的东西,这个玩意3年前就不更新了。所以在网上找了一圈,怎么安装

这里我先不说安装方式,后面的博客中,继续更新如何安装这个坑爹的python包。

安装好这个包后,你会发现,我们从微信官方下载的python代码包,里面是用python2.7版本的,那么问题来了,这里我用的python3.6,纳尼?

不兼容,怎么办,先跑起来,遇到问题在说吧!

在你的Django中,添加如下ULR,这个URL需要匹配任意的请求地址。

这里我就不阐述用(.*)的意思了,就是匹配任意的URL

因为在做URL回调的时候,微信会给你发一个类似如下图的,这样一个URL,这个测试连接地址为:https://work.weixin.qq.com/api/devtools/devtool.php

如何使用这个测试连接。

按照如下内容进行填写,企业CorpID自己找到后填写正确。点击检查问题,就会有前面一张图中所示的URL地址,这个地址就可以拿来进行本地测试。因为我是现在本地测试成后,才修改在官网上的!

拿着这个测试的URL,在你的Django上先进行URL匹配测试

我这里匹配到URL以后,返回页面

说明你的URL匹配已经成功,接下来要做的就是如何解析RUL,把URL中的内容拆分出来。

在views.py中写你的匹配的方法:

def weixin(request):
if request.method == "POST":
return HttpResponse("Weixin-NO")
else:
signature = request.GET.get('msg_signature', '')
timestamp = request.GET.get('timestamp', '')
nonce = request.GET.get('nonce', '')
echo_str = request.GET.get('echostr', '')
print(signature)
print(timestamp)
print(nonce)
print(echo_str)
return HttpResponse("Weixin-yes")

在这个请求中,获取到如下数据

好的,现在数据获取到以后,接下来需要进行URL拼接,加解密过程的验证

这里说明一下,wxcpt.VerifyURL这个方法是演示demo中的

  • WXBizMsgCrypt.py文件封装了WXBizMsgCrypt接口类,提供了用户接入企业微信的三个接口,Sample.py文件提供了如何使用这三个接口的示例,ierror.py提供了错误码。
  • WXBizMsgCrypt封装了VerifyURL, DecryptMsg, EncryptMsg三个接口,分别用于开发者验证接收消息的url、接收消息的解密以及开发者回复消息的加密过程。使用方法可以参考Sample.py文件。

我们需要微信给我们的WXBizMsgCrypt.py文件

将这个文件放到与views.py同级目录下,导入一下,方便调用。完整代码如下

这需要几个参数:

from django.http.response import HttpResponse
from wechatpy.exceptions import InvalidSignatureException
from userApp.WXBizMsgCrypt import WXBizMsgCrypt
#回调模式里面随机生成的那个Token,EncodingAESKey
sCorpID = "这个ID是企业微信号的ID"
sToken = '这是应用回调URL下面的token'
sEncodingAESKey ="回调URL下面的EncodingAESKey"
wxcpt = WXBizMsgCrypt(sToken, sEncodingAESKey, sCorpID)
def weixin(request):
if request.method == "POST":
return HttpResponse("Weixin-NO")
else:
signature = request.GET.get('msg_signature', '')
timestamp = request.GET.get('timestamp', '')
nonce = request.GET.get('nonce', '')
echo_str = request.GET.get('echostr', '')
try:
ret, sEchoStr = wxcpt.VerifyURL(signature, timestamp, nonce, echo_str)
if (ret != 0):
print("ERR: VerifyURL ret: " + str(ret))
except InvalidSignatureException:
return HttpResponse("Weixin-NO")
response = HttpResponse(sEchoStr, content_type="text/plain")
return response

这里也可以选择不捕获这个异常。不写这一步也可。

在python3.6下主要问题出现在下面这个方法调用中,前面说到微信官方给的版本是2.7我们要将官方给的事列代码进行小改动。

ret, sEchoStr = wxcpt.VerifyURL(signature, timestamp, nonce, echo_str)

下图是官方包的导入

需要做些小改动,把没有必要的东西删除。下图是我修改后的导入

之后修改微信官方给的方法,

1、找到如下方法,进行添加

2、讲微信官方给的代码,中所有的Exception,e 还有print 全部改成python3中的写法

        except Exception,e:
print e
#修改为
except Exception as e:
print (e) #所有的print改为python3的写法,print()

3、找到如下方法,修改

修改完成后,再次进行URL访问

打印一下ret 的值,如果是0,那么说明修改成功。回调验证正确。

在回调测试网站上进行测试

这里可以看到,我的EchoStr是21312,用下面这个地址,在本地进行测试时,会返回给你这个数值,如下图

这里说明验证成功。这里就可以将代码上传至服务器。然后在企业微信中点击设置,进行验证即可验证成功。

Python Django对接企业微信第三方服务回调验证的一些坑的更多相关文章

  1. java如何对接企业微信

    前言 最近实现社群对接企业微信,对接的过程遇到一些点,在此记录. 企业微信介绍 企业微信具有和微信一样的体验,用于企业内部成员和外部客户的管理,可以由此构建出社群生态. 企业微信提供了丰富的api进行 ...

  2. 3. ABP .NETCore 添加企业微信第三方登录

    1.企业微信登录步骤 1.获取企业微信Token 官方文档:https://work.weixin.qq.com/api/doc#90000/90135/91039 2.通过Token 与前端传的Co ...

  3. 发现一个企业微信第三方应用开发的疑似BUG

    1.企业微信两个账号A(超级管理员),账号B(分级管理员),账号B具有创建应用与小程序权限.2.账号B添加一个第三方应用后(创建后能看到第三方应用),使用下图接口登录时回调的agent一直为空,3.超 ...

  4. 使用python django快速搭建微信公众号后台

    前言 使用python语言,django web框架,以及wechatpy,快速完成微信公众号后台服务的简易搭建,做记录于此. wechatpy是一个python的微信公众平台sdk,封装了被动消息和 ...

  5. 如何用php开启企业微信开发的回调模式

    猜想: 懵逼 实践: 微信公众号开发的手册中甚至给出了只需要修改几个参数就能使用的范例.企业微信开发中在一个很不显眼的地方放了一个sample. https://work.weixin.qq.com/ ...

  6. python实现通过企业微信发送消息

    实现了通过企业微信发送消息,平时用于运维的告警还是不错的,相对于邮件来说,实时性更高,不过就是企业微信比较麻烦,此处不做过多解释. 企业微信api的详细请看:http://work.weixin.qq ...

  7. Java企业微信开发_09_身份验证之移动端网页授权(有完整项目源码)

    注: 源码已上传github: https://github.com/shirayner/WeiXin_QiYe_Demo 一.本节要点 1.1 授权回调域(可信域名) 在开始使用网页授权之前,需要先 ...

  8. Java企业微信开发_10_未验证域名归属,JS-SDK功能受限

    1.现象: 在企业微信后台填写可信域名后,提示:未验证域名归属,JS-SDK功能受限,如下图: 点击“申请域名校验”后, 注意:域名根目录 当时一直不清楚这个域名根目录在哪里,最后让我给试出来了 2. ...

  9. python Django框架接入微信公众平台

    1.在接入微信公众平台之前,需要在微信公众平台配置好基本信息,如下: 这个时候点击“提交”按钮,会提示“Token校验失败”,不要着急,这是必然会出现的现象,先不要退出页面,保留各项输入的数据,按第二 ...

随机推荐

  1. [Swift]LeetCode682. 棒球比赛 | Baseball Game

    You're now a baseball game point recorder. Given a list of strings, each string can be one of the 4 ...

  2. djang-异步——定时操作

    django本身是一个同步框架,flask也是,所以要把它变成异步操作的话还得专门设置一下 我的这个系统呢是windows系统,python3.7的 所以有的库是不可以兼容的 ,然后到时候会稍微修改一 ...

  3. Spring中你可能不知道的事(二)

    在上一节中,我介绍了Spring中极为重要的BeanPostProcessor BeanFactoryPostProcessor Import ImportSelector,还介绍了一些其他的零碎知识 ...

  4. SpringCloud(5)---Feign服务调用

    SpringCloud(5)---Feign服务调用 上一篇写了通过Ribbon进行服务调用,这篇其它都一样,唯一不一样的就是通过Feign进行服务调用. 注册中心和商品微服务不变,和上篇博客一样,具 ...

  5. 我的2017OKR - 年中回顾

    自从订阅了吴军老师的<硅谷来信>之后,对其中一篇介绍Google的目标管理方法OKR的文章记忆犹新.想到自己喜欢在每年年初的时候给自己定制一些规划,于是乎了解了一下OKR并重构了一下我的2 ...

  6. Android中,粗暴的方式,修改字体

    序 在 Android 下使用自定义字体已经是一个比较常见的需求了,最近也做了个比较深入的研究. 那么按照惯例我又要出个一篇有关 Android 修改字体相关的文章,但是写下来发现内容还挺多的,所以我 ...

  7. 序列化Serializable和Parcelable

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 简单记录下序列化Serializable和Parcelable的使用方法. Android中Intent如果要传递类对象,可以通过两 ...

  8. Unity实现c#热更新方案探究(一)

    转载请标明出处:http://www.cnblogs.com/zblade/ 最近研究了一下如何在unity中实现c#的热更新,对于整个DLL热更新的过程和方案有一个初步的了解,这儿就写下来,便于后续 ...

  9. 【链表问题】打卡2:删除单链表的第 K个节点

    前言 以专题的形式更新刷题贴,欢迎跟我一起学习刷题.每道题会提供简单的解答. 题目描述 在单链表中删除倒数第 K 个节点 要求 如果链表的长度为 N, 时间复杂度达到 O(N), 额外空间复杂度达到 ...

  10. 聚类——FCM

    聚类——认识FCM算法 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 一.FCM概述 FCM算法是基于对目标函数的优化基础上的一种数据聚类方法.聚类结 ...