Java实现MD5(32/16位大小写)加密

##MD5简单介绍 你们都知道,地球上任何人都有本身独一无二的指纹,这经常成为公安机关鉴别罪犯身份最值得信赖的方法;与之相似,MD5就能够为任何文件(无论其大小、格式、数量)产生一个一样独一无二的“数字指纹”,若是任何人对文件名作了任何改动,其MD5值也就是对应的“数字指纹”就会发生变化。 ##MD5能够解密吗? MD5加密原理是散列算法,散列算法也称哈希算法。 好比10除以3余数为一,4除以3余数也为一,但余数为一的就不知道这个数是哪一个了。 因此md5不能解密。也是为何扣扣密码只能重置,不能找回的缘由。 ##上代码java

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class MD5Util {
	//待加密的密码
	public static String password = "zjb0425";
	
	public static void main(String args[]) {
		//结果字符串
		String result = "";
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(password.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));
            }
            result = buf.toString();
            System.out.println("MD5(" + password + ",32小写) = " + result);
            System.out.println("MD5(" + password + ",32大写) = " + result.toUpperCase());
            System.out.println("++++++++++++++++++++++++各位大哥借过+++++++++++++++++++++++");
            System.out.println("MD5(" + password + ",16小写) = " + buf.toString().substring(8, 24));
            System.out.println("MD5(" + password + ",16大写) = " + buf.toString().substring(8, 24).toUpperCase());
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
	}
}

##代码结果算法

MD5(zjb0425,32小写) = 8e31ec4e3c3ae689b164f8ab7b1721f2 MD5(zjb0425,32大写) = 8E31EC4E3C3AE689B164F8AB7B1721F2 ++++++++++++++++++++++++各位大哥借过+++++++++++++++++++++++ MD5(zjb0425,16小写) = 3c3ae689b164f8ab MD5(zjb0425,16大写) = 3C3AE689B164F8ABapp

相关文章
相关标签/搜索