1.先大致说一下什么是MD5加密。MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),看了很多大神的文章,自己有了点理解 ,MD5其实不算是加密算法,而是一种信息的摘要。它的特性是不可逆的,所以除了暴力破解 一般逆序算法是得不到结果的。举个例子:比如1+99=100,MD5接到的字符是1和99 然后通过自己的算法最后生成100 但知道结果是100却很难推测出是通过1+99得来的。再比如 一本书的每一页取一个字,最后通过计算得出一个MD5码,但却很难通过这个MD5码去推测出这本书的内容。这也就是MD5的不可逆的原因。举的例子和对MD5的理解仅代表本人自己的观点,如有错误还请各位大神批评指正。
2.这篇文章不讨论复杂的MD5的算法实现,由于本人并非科班出生,只是在项目中要用所以大致使用了一下,具体原理等以后有空闲时间慢慢研究。话不多说,直接上代码。
3.分享两个方法①getMD5() 和 ②MD5(),传入要加密的字符str,返回加密成功的字符 . 方法①生成的是小写字母+数字,方法②生成的是大写字母+数字,方法2要是想得到小写字母+数字就把hexDigits数组中的大写换成小写。 大小写可以通过String类的方法处理
- package com.nebula.app.app.common.utils;
- import java.math.BigInteger;
- import java.security.MessageDigest;
- public class AppMD5Util {
- /**
- * 对字符串md5加密(小写+字母)
- *
- * @param str 传入要加密的字符串
- * @return MD5加密后的字符串