Java 程序中MD5的简单使用
程序员文章站
2022-03-14 19:52:20
...
写的不错
MD5 (Message-Digest Algorithm 5)消息摘要算法
虽然网上有很多例子,我们还是动手实践一下
在maven项目中导入依赖包
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.3.2</version>
</dependency>
Md5Utill类
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import org.apache.commons.codec.digest.DigestUtils;
public class MD5Utill {
public String encodeMsg(String msg) {
// 生成一个MD5加密计算摘要
MessageDigest md;
String str=null;
try {
md = MessageDigest.getInstance("MD5");
// 计算md5函数
md.update(msg.getBytes());
// digest()最后确定返回md5 hash值,返回值为8为字符串。因为md5 hash值是16位的hex值,实际上就是8位的字符
// BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;得到字符串形式的hash值
str=new BigInteger(1, md.digest()).toString(16);
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return str;
}
public static void main(String[] args) {
MD5Utill md5Utill = new MD5Utill();
System.out.println(md5Utill.encodeMsg("123123"));
}
}
结果
4297f44b13955235245b2497399d7a93
当然我还可以对加密结果或者加密前的数据进行再次加密。但是由于md5加密不是可以逆运算的,因此 对方只能将收取到的数据用同样的方式进行加密,再将加密结果进行对比。
上一篇: MD5简介及使用方式
下一篇: MD5密码+随机盐