MD5三种方式加密(16位大小、32位大小),base64两种方式加解密整理

简介: MD5 加密后的位数有两种:16 位与 32 位。16 位实际上是从 32 位字符串中取中间的第 9 位到第 24 位的部分,用 Java 语言来说,即: String md5_16 = md5_

MD5 加密后的位数有两种:16 位与 32 位。16 位实际上是从 32 位字符串中取中间的第 9 位到第 24 位的部分,用 Java 语言来说,即:

String md5_16 = md5_32.substring(8, 24)

image.png

Java实现md5加密有三种方式可供选择

1.Spring自带DigestUtils(优点,方便,代码简洁,缺点只可进行MD5加密)

spring自带jar包

import org.springframework.util.DigestUtils;

//32位,小写

String md532Lower = DigestUtils.md5DigestAsHex("adcdefg".getBytes());

//32位,大写

String md532Upper=md532Lower.toUpperCase();

//16位,小写

String md516Lower =md532Lower.substring(8, 24);

//16位,大写

String md516Upper=md532Lower.substring(8, 24).toUpperCase();

2.Java自带MessageDigest(优点,可以加密多种算法如:MD5,SHA,SHA1,SHA-224,SHA-256,SHA-384,SHA-512,缺点代码语句较多,不方便)

public static void getMD5Str(String str) {

MessageDigest messageDigest = null;

try {

messageDigest = MessageDigest.getInstance("MD5");

messageDigest.reset();

messageDigest.update(str.getBytes("UTF-8"));

} catch (NoSuchAlgorithmException e) {

System.out.println("NoSuchAlgorithmException caught!");

System.exit(-1);

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

byte[] byteArray = messageDigest.digest();

StringBuffer md5StrBuff = new StringBuffer();

for (int i = 0; i < byteArray.length; i++) {

if (Integer.toHexString(0xFF & byteArray[i]).length() == 1)

md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i]));

else

md5StrBuff.append(Integer.toHexString(0xFF & byteArray[i]));

}

//32位,小写

String md532Lower = md5StrBuff.toString();

//32位,大写

String md532Upper=md532Lower.toUpperCase();

//16位,小写

String md516Lower =md532Lower.substring(8, 24);

//16位,大写

String md516Upper=md532Lower.substring(8, 24).toUpperCase();

}

3.apache的DigestUtils(优点,代码简洁,缺点,只能MD5加密,额外引用maven依赖或手动导入jar)

org.apache.commons

commons-lang3

3.3.2

import org.apache.commons.codec.digest.DigestUtils

public static void md5(String text) throws Exception {

// 加密后的字符串

String md5str = DigestUtils.md5Hex(text);

//32位,小写

String md532Lower = md5str.toString();

//32位,大写

String md532Upper=md532Lower.toUpperCase();

//16位,小写

String md516Lower =md532Lower.substring(8, 24);

//16位,大写

String md516Upper=md532Lower.substring(8, 24).toUpperCase();

}

最后整理了一点关于MD5解密如下:

MD5解密本质上并非真正的破解,只是加速了杂凑冲撞。通俗点说,知道一个MD5串,然后使用原文进行MD5散列后再生成同样的MD5串,也就是说找到不同的原文产生相同MD5串的方法,这不是解密而称之为碰撞。MD5只有128位要真能解密的话,就变成一个超级压缩工具了!

网络上流行的MD5解密工具和在线解密网站,通常只是针对用户密码,或比较简单的数字进行破解,其方法是将常用字符串的MD5密码保存到数据库,然后再与待解密的字符串做对比,最终找到匹配的源码。

现在被黑客使用最多的一种破译密码的方法就是一种被称为"跑字典"的方法。有两种方法得到字典,一种是日常搜集的用做密码的字符串表,另一种是用排列组合方法生成的,先用MD5程序计算出这些字典项的MD5值,然后再用目标的MD5值在这个字典中检索。我们假设密码的最大长度为8位字节(8 Bytes),同时密码只能是字母和数字,共26+26+10=62个字符,排列组合出的字典的项数则是P(62,1)+P(62,2)….+P(62,8),那也已经是一个很天文的数字了,存储这个字典就需要TB级的磁盘阵列,而且这种方法还有一个前提,就是能获得目标账户的密码MD5值的情况下才可以。这种加密技术被广泛的应用于UNIX系统中,这也是为什么UNIX系统比一般操作系统更为坚固一个重要原因。

base64两种加解密方式

1.利用Java中sun.misc.BASE64Encoder()

import org.apache.commons.codec.binary.Base64;

import org.springframework.util.Assert;

import sun.plugin2.util.SystemUtil;

import java.io.IOException;

/**

* Created by crj on 2016/9/27.

*/

public class Base64Encrypt {

/**

* 编码

*

* @param bstr

* @return String

*/

public static String encode(byte[] bstr) {

return new sun.misc.BASE64Encoder().encode(bstr);

}

/**

* 解码

*

* @param str

* @return string

*/

public static byte[] decode(String str) {

byte[] bt = null;

try {

sun.misc.BASE64Decoder decoder = new sun.misc.BASE64Decoder();

bt = decoder.decodeBuffer(str);

} catch (IOException e) {

e.printStackTrace();

}

return bt;

}

}

2.利用Java中Base64.encodeBase64()

import org.apache.commons.codec.binary.Base64;

import org.springframework.util.Assert;

import sun.plugin2.util.SystemUtil;

import java.io.IOException;

public class Base64Encrypt {

public static void main(String[] args) {

String base64String = "whuang123";

byte[] result1= Base64.encodeBase64(base64String.getBytes());

String str11=new String(result1);

byte[] result2 = Base64.decodeBase64(result1);

String str12=new String(result2);

System.out.println(str11+"-------"+str12);

}

}