MD5+ASCII码递增排序 (支付宝生成签名的 复制及用)

package com.rs.util;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Map;
import java.util.TreeMap;


public class Md5Encrypt {
    /**
     * Used building output as Hex
     */
    private static final char[] DIGITS = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a',
            'b', 'c', 'd', 'e', 'f'};

    /**
     * 对字符串进行MD5加密
     *
     * @param text 明文
     * @return 密文
     */
    public static String md5(String text) {
        MessageDigest msgDigest = null;

        try {
            msgDigest = MessageDigest.getInstance("MD5");
        } catch (NoSuchAlgorithmException e) {
            throw new IllegalStateException("System doesn't support MD5 algorithm.");
        }

        try {
            msgDigest.update(text.getBytes("UTF-8")); // 注意改接口是按照指定编码形式签名

        } catch (UnsupportedEncodingException e) {

            throw new IllegalStateException("System doesn't support your  EncodingException.");

        }

        byte[] bytes = msgDigest.digest();

        String md5Str = new String(encodeHex(bytes));

        return md5Str;
    }

    private static char[] encodeHex(byte[] data) {

        int l = data.length;

        char[] out = new char[l << 1];
        // two characters form the hex value.
        for (int i = 0, j = 0; i < l; i++) {
            out[j++] = DIGITS[(0xF0 & data[i]) >>> 4];
            out[j++] = DIGITS[0x0F & data[i]];
        }

        return out;
    }

    /**
     * 签名算法
     *
     * @return
     */
    public static Object createSign(Map<String, Object> params) {
        int i = 0;
        StringBuilder sb = new StringBuilder();
        // 将参数以参数名的字典升序排序
        Map<String, Object> sortParams = new TreeMap<>(params);
        // 遍历排序的字典,并拼接"key=value"格式
        for (Map.Entry<String, Object> entry : sortParams.entrySet()) {
            String key = entry.getKey();
            Object value = ((String) entry.getValue()).trim();
            if (null != value && !value.equals("") ) {
                if (i != 0)
                	sb.append("&");
                sb.append(key).append("=").append(value);
            }
            i++;
        }
        System.out.println(sb);
        return Md5Encrypt.md5(sb.toString() + "需要的Key");
    }
}
在Java中,获取所有请求参数并按照首个字符的ASCII码递增排序,可以分为两步操作: 1. 获取请求参数:通常,你可以从HttpServletRequest对象中获取HTTP请求的所有参数。这里是一个简单的示例: ```java Map<String, String[]> parameters = request.getParameterMap(); ``` `getParameterMap()`返回的是一个String到String数组的映射,包含了所有的参数名及其对应的值。 2. 按照ASCII码排序MD5加密:首先,你需要将每个参数名转换为大写字母,并计算其首字符的ASCII码,然后对参数名和对应的值进行组合,使用MD5算法加密。以下是一个简单的步骤描述: - 遍历参数映射,获取每个键值对(key, value)。 - 将键的首字符转化为ASCII码,例如`Character.getNumericValue(key.charAt(0))`。 - 使用HashMap存储键值对,用ASCII码作为排序依据。 - 对于每个键值对,先进行MD5加密,如使用`MessageDigest`和`DigestInputStream`: ```java MessageDigest md = MessageDigest.getInstance("MD5"); byte[] encryptedKey = md.digest(key.getBytes(Charset.forName("UTF-8"))); ``` 完成这两个部分后,你可以创建一个新的Map,其中的键是按ASCII码排序后的密文。下面是一个简化版的代码片段展示这个过程: ```java Map<byte[], String> sortedAndEncryptedParams = new TreeMap<>((a, b) -> a[0] - b[0]); // 使用TreeMap进行自然排序 for (Entry<String, String[]> entry : parameters.entrySet()) { String key = entry.getKey().toUpperCase(); // 转换为大写 byte[] encryptedKey = MD5Encrypt(key); // 自定义MD5加密函数 sortedAndEncryptedParams.put(encryptedKey, entry.getValue()[0]); } // MD5Encrypt方法示例 public static byte[] MD5Encrypt(String str) { try { return MessageDigest.getInstance("MD5").digest(str.getBytes()); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } } ``` 注意:实际应用中,MD5加密用于加密字符串,并非用于排序,上述代码只是为了演示排序+加密的过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Heart&Fire

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值