MD5算法原理及Java实现

原文链接:MD5算法原理及Java实现
一、什么是MD5算法?

MD5称为消息摘要算法(MD5 Message-Digest Algoritm),是被广泛使用的密码散列函数,可产生16位的hash value,

用于确保信息传输的完整一直性。

MD5输入任意不同长度的信息,可固定输出32-bit数据,最后联合输出固定的信息摘要。

二、MD5的功能?

1、一致性验证,对一段信息产生摘要信息,以防止被篡改。无论任何形式的文件,都会产生一个独一无二的MD5数据指纹,

我们经常在下载文件的时候用于文件比对。
2、数字签名,对一端信息message(字符串)产生fingerprint(指纹),以防着被篡改。

三、MD5的特性?

1、长度固定:无论字符串长度,加密后的字符长度都相等,便于统计计算。

2、便于加密:无论字符串还是文件,正向加密过程便于开发者理解。

3、可多变性:两个相近的字符串只要有细微的差别,所产生的密文完全是不一样的。

4、不可逆性:知道正向加密,却是无法算出逆向加密密码,这样大大提高了数据的安全性。

四、JAVA实现MD5?

1、字符串加密

//MD5-32位签名算法
 //MD5-32位签名算法
    public static String MD5Code(String source) {
        String resultStr = null;
        try {
            MessageDigest md5 = MessageDigest.getInstance("MD5");//MessageDigest jdk 1.8数字签名
            if (!"".equals(source) && null != source)
                resultStr = byteArrayToHexString(md5.digest(source.getBytes())); //字符串报文
            else
                return "数据源不可为空!";
        } catch (Exception e) {
            e.printStackTrace();
        }
        return resultStr;
    }

    // byte[]数组 转换String
    private static String byteArrayToHexString(byte[] bytes) {
        StringBuffer resultStrBuff = new StringBuffer();
        for (int i = 0; i < bytes.length; i++)
            resultStrBuff.append(byteToHexString(bytes[i]));

        return resultStrBuff.toString();
    }

    //byte 转换String
    private static String byteToHexString(byte bytes) {
        int n = bytes;
        if (n < 0)
            n += 256;
        int d1 = n / 16;//求整数
        int d2 = n % 16; //求余数
        return hexDigits[d1] + hexDigits[d2];
    }

    //hex 16进制取值(取下标数)
    private static final String hexDigits[] =
            {"0", "1", "2", "3", "4", "5", "6", "7", "a", "b", "c", "d", "e", "f", "g", "h"};
"h"};

//可逆签名方法编写

//编写可逆加密
    public static String encryption(String source) {
        char[] a = source.toCharArray();
        for (int i = 0; i < a.length; i++)
            a[i] = (char) (a[i] ^ 's');
        String str = new String(a);
        return str;
    }

    // 加密后解密
    public static String JM(String source) {
        char[] a = source.toCharArray();
        for (int i = 0; i < a.length; i++) {
            a[i] = (char) (a[i] ^ 't');
        }
        String str = new String(a);
        return str;
    }

以上便是Java对于MD5的简单签名算法。

面向开发过程,记录学习之路。

发布了87 篇原创文章 · 获赞 47 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/qq_42685333/article/details/98038623