JAVA sign按照字典排序进行签名工具类

1 篇文章 0 订阅
import com.weiwen.provider.service.MapKeyComparator;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.*;

public class MD5 {


    public static void main(String[] args) {
        MD5 md5 = new MD5();
        String ss = md5.md5("10012843443");
        String s="61430CA53505866C97CD7D45FD01966A";
        System.out.println(s.length());
        System.err.println(ss);
        Map<String, Object>map=new HashMap<String,Object>();
        map.put("name", "harry");
        map.put("b", "harry");
        map.put("level", "top");
        map.put("g", "");
        map.put("m", "lal");
        map.put("alary", 1000);
        String sign = sign(map);
        System.out.println("签名为================="+md5(sign));


    }
    
   /**
     *
     * @param plainText
     *            明文
     * @return 32位密文
     */
    public String encryption(String plainText) {
        String md5 = new String();
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(plainText.getBytes());
            byte b[] = md.digest();

        int i;

        StringBuffer buf = new StringBuffer("");
        for (int offset = 0; offset < b.length; offset++) {
            i = b[offset];
            if (i < 0)
                i += 256;
            if (i < 16)
                buf.append("0");
            buf.append(Integer.toHexString(i));
        }

        md5 = buf.toString();

    } catch (Exception e) {
        e.printStackTrace();
    }
    return md5;
}


    /**
     * 使用 Map按key进行排序
     * @param map
     * @return
     */
    public static Map<String, Object> sortMapByKey(Map<String, Object> map) {
        if (map == null || map.isEmpty()) {
            return null;
        }

        Map<String, Object> sortMap = new TreeMap<String, Object>(new MapKeyComparator());

        sortMap.putAll(map);

        return sortMap;
    }


    /**
     * 签名
     */
    public static String sign(Map<String,Object>map){
        System.out.println("排序前:"+map);
        map=sortMapByKey(map);
        System.out.println("排序后"+map);
        List<Object> list=new ArrayList<Object>();
        String str="";
        Iterator<String> iter = map.keySet().iterator();
        while(iter.hasNext()){
            String key=iter.next();
            Object value = map.get(key);
            list.add(key+"="+value);
        }
        int leng=list.size()-1;
        for(int i=0;i<leng;i++){
            str+=(list.get(i)+"&");//拼索要加密的字符串格式
        }
        str+=list.get(leng);
//        System.out.println("要加密的字符串:"+str);//所要加密的字符串
//        System.out.println("加密之后的密文"+md5(str));//加密之后的密文
     return str;
    }


}

MapKeyComparator类

import java.util.Comparator;

public class MapKeyComparator implements Comparator<String> {
    @Override
    public int compare(String o1, String o2) {
        return o1.compareTo(o2);
    }
}

以下是结果:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,我们可以使用MessageDigest类来生成sign签名)。 首先,我们需要引入java.security包下的MessageDigest类。然后,我们可以使用MessageDigest.getInstance("MD5")方法获得一个实例化的MD5消息摘要对象。 接下来,我们可以使用DigestUtils类中的md5Hex方法来对字符串进行摘要计算。md5Hex方法接受一个字符串作为输入,并返回对该字符串进行MD5计算后的摘要结果。 以下是一个示例代码: import java.security.MessageDigest; import org.apache.commons.codec.digest.DigestUtils; public class SignGenerator { public static void main(String[] args) { String input = "HelloWorld"; String sign = generateSign(input); System.out.println("生成的Sign为:" + sign); } public static String generateSign(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] digest = md.digest(input.getBytes()); return DigestUtils.md5Hex(digest); } catch (Exception ex) { ex.printStackTrace(); } return null; } } 在上述代码中,我们定义了一个generateSign方法,该方法接受一个字符串作为输入,并返回生成的sign签名)。首先,我们使用MessageDigest.getInstance("MD5")获取一个MD5消息摘要对象。然后,我们使用MD5摘要对象的digest方法对输入字符串进行摘要计算,得到一个字节数组。最后,我们使用DigestUtils.md5Hex方法将该字节数组转换为一个十六进制的字符串表示的摘要结果。 通过调用generateSign方法,并传入待签名的输入字符串,我们可以获取生成的sign。在上述示例中,我们对字符串"HelloWorld"进行签名生成,并将签名结果打印输出。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值