企业微信-服务商后台绑定小程序时,指令回调、数据回调、测试安装

1、企业微信API文档

https://work.weixin.qq.com/api/doc/90001/90142/90595 服务商注册应用

https://work.weixin.qq.com/api/doc/90001/90145/90446 加解密库下载与返回码

下载JAVA库json版本

image

拷贝aes文件夹到自己的工程

image

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&timestamp=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;
    }

}

3、修改JsonParse.java工具类中,json解析时的属性名

image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容