博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java企业微信开发_01_接收消息服务器配置
阅读量:6169 次
发布时间:2019-06-21

本文共 4300 字,大约阅读时间需要 14 分钟。

一、准备阶段

需要准备事项:

1.一个能在公网上访问的项目:

                     见:

2.一个企业微信账号: 

                     去注册:()

3.策略文件

                     见:

4.接入验证的 微信加解密包

此包封装了对 msg_signature对请求进行校验的相关操作,直接用就可以了

                      下载地址:

二、接收消息服务器配置

2.1 接收消息服务器参数配置:

    在企业微信的管理端后台,进入需要设置接收消息的目标应用,点击“接收消息”的“设置”,进入如下页面

 

 

  • URL是企业应用接收企业微信推送请求的访问协议和地址,支持http或https协议。
  • Token可由企业任意填写,用于生成签名。
  • EncodingAESKey用于消息体的加密,是AES密钥的Base64编码。

 2.1.1 验证URL有效性

当点击“保存”提交以上信息时,企业微信将发送GET请求到填写的URL上,GET请求携带以下四个参数

 

参数 必须 说明
msg_signature 企业微信加密签名,msg_signature结合了企业填写的token、请求中的timestamp、nonce参数、加密的消息体
timestamp 时间戳
nonce 随机数
echostr 加密的随机字符串,以msg_encrypt格式提供。需要解密并返回echostr明文,解密后有random、msg_len、msg、$CorpID四个字段,其中msg即为echostr明文

 

 企业通过参数msg_signature对请求进行校验,如果确认此次GET请求来自企业微信,那么企业应该对echostr参数解密并原样返回echostr明文(不能加引号,不能带bom头,不能带换行符),则接入验证生效,接收消息才能开启。

后续推送消息给企业时都会在请求URL中带上以上参数(echostr除外),校验方式与首次验证URL一致。

 

2.2 下载的加解密包添加到项目中

   注意要在lib中添加 commons-codec-1.9.jar

 

 

2.3 微信相关参数封装类-WeiXinParamesUtil.java

此类集中管理微信开发中所要用到的微信的相关参数

1 package com.ray.util; 2 /** 3  * 微信参数 4  * @author shirayner 5  * 6  */ 7 public class WeiXinParamesUtil { 8     //token 9     public final static String token = "ray";10     // encodingAESKey11     public final static String encodingAESKey = "z2W9lyOAR1XjY8mopEmiSqib0TlBZzCFiCLp6IdS2Iv";12     //企业ID13     public final static String corpId = "ww92f5da92bb24696e";14     //应用的凭证密钥15     public final static String corpsecret = "I73733veH3uCs6H_ijPvIq0skjTaOePsFF4MyCEi3Ag";16     17     18     19 }
View Code

 

2.4 核心servlet-CoreServlet.java

2.1步点击提交之后,CoreServlet会收到请求,并调用加解密包中的工具类 对相关请求参数进行处理,以通过参数msg_signature对请求进行校验

1 package com.ray.servlet; 2    3    4 import java.io.IOException;   5 import java.io.PrintWriter;   6    7 import javax.servlet.ServletException;   8 import javax.servlet.http.HttpServlet;   9 import javax.servlet.http.HttpServletRequest;  10 import javax.servlet.http.HttpServletResponse;  11 12 import com.qq.weixin.mp.aes.AesException;13 import com.qq.weixin.mp.aes.WXBizMsgCrypt;14 import com.ray.util.WeiXinParamesUtil;15 16   17 18   19 /** 20  * 核心请求处理类 21  *  22  * @author liufeng 23  * @date 2013-05-18 24  */  25 public class CoreServlet extends HttpServlet {  26     private static final long serialVersionUID = 4440739483644821986L;  27   28     /** 29      * 确认请求来自微信服务器 30      */  31     public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {      32         33         // 微信加密签名  34             String msg_signature = request.getParameter("msg_signature");  35             // 时间戳  36             String timestamp = request.getParameter("timestamp");  37             // 随机数  38             String nonce = request.getParameter("nonce");  39             // 随机字符串  40             String echostr = request.getParameter("echostr");  41       42             System.out.println("request=" + request.getRequestURL());  43       44             PrintWriter out = response.getWriter();  45             // 通过检验msg_signature对请求进行校验,若校验成功则原样返回echostr,表示接入成功,否则接入失败  46             String result = null;  47             try {48                 WXBizMsgCrypt wxcpt = new WXBizMsgCrypt(WeiXinParamesUtil.token, WeiXinParamesUtil.encodingAESKey, WeiXinParamesUtil.corpId);  49                 result = wxcpt.VerifyURL(msg_signature, timestamp, nonce, echostr);  50             } catch (AesException e) {  51                 e.printStackTrace();  52             }  53             if (result == null) {  54                 result = WeiXinParamesUtil.token;  55             }  56             out.print(result);  57             out.close();  58             out = null;  59     }  60   61     /** 62      * 处理微信服务器发来的消息 63      */  64     public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  65 66         67     }  68   69 }
View Code

 

2.5 在web.xml中配置servlet

1 
2
6
7
coreServlet
8
9 com.ray.servlet.CoreServlet10
11
12 13 14
15
16
coreServlet
17
/coreServlet
18
19 20 21
22
index.jsp
23
24
View Code

 

2.6 提交成功

点击2.1步中的保存按钮,会提示配置成功

 

转载地址:http://cjnba.baihongyu.com/

你可能感兴趣的文章
LINE上市:一场迟到、勇敢又无奈的IPO
查看>>
OA选型:OA系统工作流是核心
查看>>
如何发现“利用DNS放大攻击”的服务器
查看>>
《Arduino开发实战指南:LabVIEW卷》——第2章 Arduino软件
查看>>
京津冀大数据走廊起笔谋篇
查看>>
WIFI连网一“吻”通 黑科技让无线路由器更智能
查看>>
Ovum光器件首席分析师:硅光子不是唯一解决方案
查看>>
大数据发展进入快车道 未来会呈现高速增长
查看>>
JVM基础:JVM内存组成及分配
查看>>
数据库锁和数据库隔离级别
查看>>
Linux下的内核测试工具——perf使用简介
查看>>
《从问题到程序:用Python学编程和计算》——2.3 内置函数和数学函数包
查看>>
《Photoshop修饰与合成专业技法》目录—导读
查看>>
《Metasploit渗透测试手册》—第1章1.10节分析数据库中存储的渗透测试结果
查看>>
《Adobe Acrobat XI经典教程》—第2课减小文件大小
查看>>
《数据库技术原理与应用教程》一第2章 数据库的基础知识
查看>>
QuaggaJS —— 纯 JavaScript 开发的条形码扫描
查看>>
在图片中加入噪点就能骗过 Google 最顶尖的图像识别 AI
查看>>
免费下载!业界首部安卓热修复宝典出炉,阿里技术大牛联袂推荐
查看>>
OpenID 关联认证提供 CoreOS dex
查看>>