1、企业微信API文档
https://work.weixin.qq.com/api/doc/90001/90142/90595 服务商注册应用
https://work.weixin.qq.com/api/doc/90001/90145/90446 加解密库下载与返回码
下载JAVA库json版本
拷贝aes文件夹到自己的工程
2、指令回调、数据回调、测试安装接口
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
/**
* 微信缓存表 前端控制器
*/
@Slf4j
@RestController
@RequestMapping("api/admin/qywechat")
public class QyWeChatController {
/**
* ------------企业微信验证回调URL---------------
* 企业开启回调模式时,企业微信会向验证url发送一个get请求
* 假设点击验证时,企业收到类似请求:
* GET /cgi-bin/wxpush?msg_signature=5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3×tamp=1409659589&nonce=263014780&echostr=P9nAzCzyDtyTWESHep1vC5X9xho%2FqYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp%2B4RPcs8TgAE7OaBO%2BFZXvnaqQ%3D%3D
* HTTP/1.1 Host: qy.weixin.qq.com
* <p>
* 接收到该请求时,企业应 1.解析出Get请求的参数,包括消息体签名(msg_signature),时间戳(timestamp),随机数字串(nonce)以及企业微信推送过来的随机加密字符串(echostr),
* 这一步注意作URL解码。
* 2.验证消息体签名的正确性
* 3. 解密出echostr原文,将原文当作Get请求的response,返回给企业微信
* 第2,3步可以用企业微信提供的库函数VerifyURL来实现。
*/
@RequestMapping(value = "/dataCallback")
@ResponseBody
public String dataCallback(@RequestBody(required = false) String reqStr, QyWechatCallBackReq req) throws AesException {
//需要返回的明文
String sEchoStr = null;
// post 请求,用于测试安装
if (null != reqStr) {
//第三方应用SuiteIDID
String SuiteID = "";
String sToken = "";
String sEncodingAESKey = "";
JSONObject jsonObject = JSONUtil.xmlToJson(reqStr);
String xmlData = JSONUtil.toJsonStr(jsonObject.get("xml"));
log.info("指令回调请求参数xmlData:{}", xmlData);
// 对msg_signature进行检验 并且解密获得消息结构体
WXBizJsonMsgCrypt wxcpt = new WXBizJsonMsgCrypt(sToken, sEncodingAESKey, SuiteID);
// 回调的key值
String msgStructure = wxcpt.DecryptMsg(req.getMsg_signature(), req.getTimestamp(), req.getNonce(), xmlData);
log.info("指令回调获取到的数据为:{}", msgStructure);
return "success";
} else {
// get 请求,用于验证回调
//服务商CORPID
String sCorpID = "";
String sToken = "";
String sEncodingAESKey = "";
WXBizJsonMsgCrypt wxcpt = new WXBizJsonMsgCrypt(sToken, sEncodingAESKey, sCorpID);
// 解析出url上的参数值如下:
String sVerifyMsgSig = req.getMsg_signature();
String sVerifyTimeStamp = req.getTimestamp();
String sVerifyNonce = req.getNonce();
String sVerifyEchoStr = req.getEchostr();
try {
sEchoStr = wxcpt.VerifyURL(sVerifyMsgSig, sVerifyTimeStamp,
sVerifyNonce, sVerifyEchoStr);
log.info("verifyurl echostr: " + sEchoStr);
// 验证URL成功,将sEchoStr返回
return sEchoStr;
} catch (Exception e) {
//验证URL失败,错误原因请查看异常
e.printStackTrace();
}
}
return sEchoStr;
}
}