java MD5加密检验思路

1、MD5的加密方式是一种哈希加密。一些主流的编程语言都已经实现了MD5的加密。
2、MD5在明文的情况下,MD5就可以加密。
3、MD5是不可逆的,只能加密,不能解密。

思路:
1、接收方和发送方先确定一个key(用于保证数据和验证码正确)
2、对数据+key进行MD5加密,生成MD5校验码
3、把数据和检验码一起传到接收方
4、接收方接用收到的数据+自己手上的key进行MD5加密
5、对比两个MD5,确认数据是否正确

代码:

import java.security.MessageDigest;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

public class MD5Test {

    public static void main(String[] args) {
        //客户端所需要传输的数据加上key 一起传给MD5Encode 生成MD5
        //客户端传输数据的时候不传key
        //服务端用服务端手上的key和接收到的数据再生成一个MD5来对比 以此保证数据正确
        String str= "1";
        String clientkey = "sw23klkj3nm23";
        String clientstr = str + clientkey;
        //生成MD5
        String result = MD5Test.MD5Encode(clientstr, "UTF-8").toUpperCase();
        System.out.println(result);

        //用接收到的数据生成一个新的MD5 与原来的MD5对比
        String checkstr = "1";
        String serverkey = "sw23klkj3nm23";
        String serverstr = checkstr + serverkey;
        System.out.print("验证密码是否正确:");    
        if(validatePassword(result, serverstr, "UTF-8")) {    
            System.out.println("正确");    
        }    
        else {    
            System.out.println("错误");    
        } 

    }

    //通过获取参数并且生成新的MD5校验码 然后和 获取到的MD5校验码 对比 以此验证传过来的数据是否被修改
    public static boolean validatePassword(String origin, String inputString, String charsetname){    
        if(origin.equals(MD5Encode(inputString,charsetname).toUpperCase())){    
            return true;    
        } else{    
            return false;    
        }    
    } 

    //通过获取数据来生成MD5验证码   charsetname为"UTF-8"编码比较好
    public static String MD5Encode(String origin, String charsetname) {
        String resultString = null;
        try {
            resultString = new String(origin);
            MessageDigest md = MessageDigest.getInstance("MD5");
            byte[] digestString = md.digest(resultString.getBytes(charsetname));
            if (charsetname == null || "".equals(charsetname))
                resultString = byteArrayToHexString(digestString);
            else
                resultString = byteArrayToHexString(digestString);
        } catch (Exception exception) {
        }
        return resultString;
    }

    //生成MD5序列的逻辑
    private static String byteArrayToHexString(byte b[]) {
        StringBuffer resultSb = new StringBuffer();
        String byteToHex = null;
        for (int i = 0; i < b.length; i++){
            byteToHex = byteToHexString(b[i]);
            resultSb.append(byteToHex);
        }
        return resultSb.toString();
    }

    //逻辑中每一位数据 在这里对应转换成两个字符
    private static String byteToHexString(byte b) {
        int n = b;
        if (n < 0)
            n += 256;
        int d1 = n / 16;
        int d2 = n % 16;
        return hexDigits[d1] + hexDigits[d2];
    }

    //转换字符的集合 这里可以根据自己喜好改一下顺序 达到改变生成的MD5的结果的作用 慢慢试 估计可能可以清楚顺序的
    private static final String hexDigits[] = { "0", "1", "2", "3", "4", "5",
            "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };

}

MD5加密这个东西估计就这样先了,做个模板,下次可以直接复制粘贴。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值