Java对接口接收到的数据进行MD5签名验证

第一步:创建一个TreeMap来对接收到的数据进行排序,确保参数按照参数名的ASCII码从小到大排序。
第二步:在verifySignature()方法中,构建待签名的字符串stringA,并根据给定的KEY拼接了stringSignTemp。使用md5Hash()方法计算stringSignTemp的MD5摘要,并将摘要转换为大写。将计算得到的签名signValue与接口获取到的签名receivedSign进行比较,以验证签名是否匹配。
以下是代码示例,供参考。

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;

public class MD5Util {

    private static final String KEY = "key"; // 替换为真实的key值

    public static boolean verifySignature(Map<String, String> receivedData, String receivedSign) {

        // 将接收到的数据按照参数名进行排序
        TreeMap<String, String> sortedData = new TreeMap<>(receivedData);

        // 构建待签名字符串
        StringBuilder stringA = new StringBuilder();
        for (Map.Entry<String, String> entry : sortedData.entrySet()) {
            String key = entry.getKey();
            String value = entry.getValue();
            if (value != null && !value.isEmpty()) {
                stringA.append(key).append("=").append(value).append("&");
            }
        }

        // 拼接key,并进行MD5运算
        String stringSignTemp = stringA.append("key=").append(KEY).toString();
        String signValue = md5Hash(stringSignTemp).toUpperCase();

        // 验证签名是否匹配
        return signValue.equals(receivedSign);
    }

    private static String md5Hash(String data) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            byte[] hashBytes = md.digest(data.getBytes());

            StringBuilder hexString = new StringBuilder();
            for (byte hashByte : hashBytes) {
                String hex = Integer.toHexString(0xFF & hashByte);
                if (hex.length() == 1) {
                    hexString.append('0');
                }
                hexString.append(hex);
            }

            return hexString.toString();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return null;
    }

    public static void main(String[] args) {
        Map<String, String> receivedData = new HashMap<>();
        receivedData.put("key1", "value1");
        receivedData.put("key2", "value2");

        String receivedSign = "receivedSign";  // 接口获取到的sign值

        boolean isValidSignature = verifySignature(receivedData, receivedSign);
        System.out.println("签名是否验证成功? " + isValidSignature);
    }
}

注意:示例中的KEY值需要替换为真实的值。
如有纰漏,望大家斧正。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,关于Java后台微信支付签名算法(MD5)的问题,我可以给您提供一些基本思路和代码实现: 首先,微信支付的签名算法主要包含以下几步: 1. 将请求参数按照字典序排序,并拼接成字符串(参数值为空的不参与签名)。 2. 在拼接好的字符串后面加上商户支付密钥,并进行MD5运算,得到签名字符串。 3. 将签名字符串转换为大写字母形式后作为最终的签名值。 以下是Java代码实现: ```java import java.util.*; import java.security.*; import java.io.*; public class WechatPaySign { // 微信支付商户密钥 private static final String KEY = "your_mch_key"; // 微信支付签名算法(MD5) public static String sign(Map<String, String> params) { // 将参数按照字典序排序 List<String> keys = new ArrayList<String>(params.keySet()); Collections.sort(keys); // 拼接参数,不包括空值参数 StringBuilder sb = new StringBuilder(); for (String key : keys) { String value = params.get(key); if (value != null && !"".equals(value) && !"sign".equals(key) && !"key".equals(key)) { sb.append(key).append("=").append(value).append("&"); } } sb.append("key=").append(KEY); // 对拼接好的字符串进行MD5运算 String sign = null; try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] bytes = md.digest(sb.toString().getBytes("UTF-8")); sign = byteArrayToHexString(bytes); } catch (Exception e) { e.printStackTrace(); } return sign.toUpperCase(); } // 将字节数组转换为十六进制字符串 private static String byteArrayToHexString(byte[] bytes) { StringBuilder sb = new StringBuilder(); for (byte b : bytes) { String hex = Integer.toHexString(b & 0xFF); if (hex.length() == 1) { sb.append("0"); } sb.append(hex); } return sb.toString(); } } ``` 以上代码中,sign方法接收一个Map类型的参数,其中包含微信支付请求的各个参数,例如appid、mch_id、nonce_str、body、out_trade_no、total_fee、spbill_create_ip、notify_url等。在方法内部,首先将参数按照字典序排序,并将其拼接成字符串。然后,在拼接好的字符串后面加上商户支付密钥,并进行MD5运算,得到签名字符串。最后,将签名字符串转换为大写字母形式后作为最终的签名值。 需要注意的是,微信支付请求中的一些参数值需要根据实际情况进行编码或者加密,例如body参数需要进行UTF-8编码,而notify_url参数需要进行URL编码。此外,微信支付中还涉及到一些其他的安全问题,例如支付结果通知的验证、退款操作的安全等问题,需要开发者在实际开发进行注意。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值