微信公众号回调地址设置

微信公众号回调地址设置

( 设置好按保存之后 微信会向该接口发送验证消息(token) 如果验证成功 配置才能生效,否则会提示错误,一会附上如何验证的代码 )

1.在微信公众平台 => 基本配置中 => 设置地址

在这里插入图片描述

2.设置服务器地址

以我的回调地址为例 http:xxxxx/wxMpSendMsgCallBack

3.设置Token 可以写自己喜欢的英文

4.消息解密方式 我这里用的是 明文 ,可以根据项目需求来修改

5.完整代码

5.1 控制器

/**
 * 微信公众号回调地址
 */
@RequestMapping(value = "/wxMpSendMsgCallBack")
public String shareTestCallBack(HttpServletRequest request) throws AesException {

    String msgSignature = request.getParameter("signature");
    String msgTimestamp = request.getParameter("timestamp");
    String msgNonce = request.getParameter("nonce");
    String echostr = request.getParameter("echostr");
    if (WXPublicUtils.verifyUrl(msgSignature, msgTimestamp, msgNonce)) {
        return echostr;
    }

    return s;
}

5.2 WXPublicUtils工具类 代码中xxxx改成设置中的token

package org.jeecg.modules.common.util.wxcallback;

public class WXPublicUtils {
    /**
     * 验证Token
     * @param msgSignature 签名串,对应URL参数的signature
     * @param timeStamp 时间戳,对应URL参数的timestamp
     * @param nonce 随机串,对应URL参数的nonce
     *
     * @return 是否为安全签名
     * @throws AesException 执行失败,请查看该异常的错误码和具体的错误信息
     */
    public static boolean verifyUrl(String msgSignature, String timeStamp, String nonce)
            throws AesException {
        // 这里的 WXPublicConstants.TOKEN 填写你自己设置的Token就可以了
        String signature = SHA1.getSHA1("xxxxxxxxxxxxxxxx", timeStamp, nonce);
        if (!signature.equals(msgSignature)) {
            throw new AesException(AesException.ValidateSignatureError);
        }
        return true;
    }
}

5.3 SHA1类 用SHA1算法验证Token

package org.jeecg.modules.common.util.wxcallback;

import java.security.MessageDigest;
import java.util.Arrays;

public class SHA1 {

    /**
     * 用SHA1算法验证Token
     *
     * @param token     票据
     * @param timestamp 时间戳
     * @param nonce     随机字符串
     * @return 安全签名
     * @throws AesException
     */
    public static String getSHA1(String token, String timestamp, String nonce) throws AesException {
        try {
            String[] array = new String[]{token, timestamp, nonce};
            StringBuffer sb = new StringBuffer();
            // 字符串排序
            Arrays.sort(array);
            Arrays.sort(array);
            for (int i = 0; i < 3; i++) {
                sb.append(array[i]);
            }
            String str = sb.toString();
            // SHA1签名生成
            MessageDigest md = MessageDigest.getInstance("SHA-1");
            md.update(str.getBytes());
            byte[] digest = md.digest();

            StringBuffer hexstr = new StringBuffer();
            String shaHex = "";
            for (int i = 0; i < digest.length; i++) {
                shaHex = Integer.toHexString(digest[i] & 0xFF);
                if (shaHex.length() < 2) {
                    hexstr.append(0);
                }
                hexstr.append(shaHex);
            }
            return hexstr.toString();
        } catch (Exception e) {
            e.printStackTrace();
            throw new AesException(AesException.ComputeSignatureError);
        }
    }
}

5.4 自定义异常类AesException

package org.jeecg.modules.common.util.wxcallback;
@SuppressWarnings("serial")
public class AesException extends Exception {

    public final static int OK = 0;
    public final static int ValidateSignatureError = -40001;
    public final static int ParseXmlError = -40002;
    public final static int ComputeSignatureError = -40003;
    public final static int IllegalAesKey = -40004;
    public final static int ValidateAppidError = -40005;
    public final static int EncryptAESError = -40006;
    public final static int DecryptAESError = -40007;
    public final static int IllegalBuffer = -40008;
    public final static int EncodeBase64Error = -40009;
    public final static int DecodeBase64Error = -40010;
    public final static int GenReturnXmlError = -40011;

    private int code;

    private static String getMessage(int code) {
        switch (code) {
            case ValidateSignatureError:
                return "签名验证错误";
            case ParseXmlError:
                return "xml解析失败";
            case ComputeSignatureError:
                return "sha加密生成签名失败";
            case IllegalAesKey:
                return "SymmetricKey非法";
            case ValidateAppidError:
                return "appid校验失败";
            case EncryptAESError:
                return "aes加密失败";
            case DecryptAESError:
                return "aes解密失败";
            case IllegalBuffer:
                return "解密后得到的buffer非法";
            case EncodeBase64Error:
                return "base64加密错误";
            case DecodeBase64Error:
                return "base64解密错误";
            case GenReturnXmlError:
                return "xml生成失败";
            default:
                return null;
        }
    }

    public int getCode() {
        return code;
    }

    public AesException(int code) {
        super(getMessage(code));
        this.code = code;
    }
}
ll;
        }
    }

    public int getCode() {
        return code;
    }

    public AesException(int code) {
        super(getMessage(code));
        this.code = code;
    }
}

6.配置nginx服务

在niginx中配置 访问域名跳转到刚才回调地址对应的端口 我的是8599
在这里插入图片描述

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
引用\[1\]中的代码是一个Java类,定义了一个名为WxServiceMsgDto的核心类,该类使用了@XmlRootElement和@XmlAccessorType注解来指定XML的根元素和访问类型。该类包含了一些成员变量,如event、content、msgType等,以及对应的getter和setter方法。此外,还定义了两个枚举类WxEeventType和WxMessageType,分别表示微信事件类型和消息类型。 引用\[2\]中的代码是一个接收微信回调的方法receiveXml,该方法接收HttpServletRequest和HttpServletResponse作为参数。在方法中,首先进行了微信服务器的验证,然后通过parseXml方法解析了请求的XML数据,并将解析结果存储在wxdata变量中。 引用\[3\]中的代码是一个用于验证请求签名的方法checkSignature。该方法接收signature、timestamp和nonce作为参数,首先对这三个参数进行字典序排序,然后将排序后的字符串进行SHA-1加密,最后将加密后的结果与signature进行比较,以验证请求是否来自微信服务器。 综上所述,要实现微信公众号的关注回调功能,可以使用上述代码中的WxServiceMsgDto类和receiveXml方法。在receiveXml方法中,可以根据解析得到的wxdata数据进行关注公众号的逻辑处理。同时,可以使用checkSignature方法对请求的签名进行验证,确保请求来自微信服务器。 #### 引用[.reference_title] - *1* [微信公众号关注回调](https://blog.csdn.net/john1337/article/details/121860490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [java 获取微信公众号回调与回复](https://blog.csdn.net/weixin_40836984/article/details/83142435)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值