md5加密 java实现md5加密示例
人气:0想了解java实现md5加密示例的相关内容吗,在本文为您仔细讲解md5加密的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:java,md5加密,下面大家一起来学习吧。
复制代码 代码如下:
/**
* 实现MD5加密
*
*/
public class MD5 {
/**
* 获取加密后的字符串
* @param input
* @return
*/
public static String stringMD5(String pw) {
try {
// 拿到一个MD5转换器(如果想要SHA1参数换成”SHA1”)
MessageDigest messageDigest =MessageDigest.getInstance("MD5");
// 输入的字符串转换成字节数组
byte[] inputByteArray = pw.getBytes();
// inputByteArray是输入字符串转换得到的字节数组
messageDigest.update(inputByteArray);
// 转换并返回结果,也是字节数组,包含16个元素
byte[] resultByteArray = messageDigest.digest();
// 字符数组转换成字符串返回
return byteArrayToHex(resultByteArray);
} catch (NoSuchAlgorithmException e) {
return null;
}
}
public static String byteArrayToHex(byte[] byteArray) {
// 首先初始化一个字符数组,用来存放每个16进制字符
char[] hexDigits = {'0','1','2','3','4','5','6','7','8','9', 'A','B','C','D','E','F' };
// new一个字符数组,这个就是用来组成结果字符串的(解释一下:一个byte是八位二进制,也就是2位十六进制字符(2的8次方等于16的2次方))
char[] resultCharArray =new char[byteArray.length * 2];
// 遍历字节数组,通过位运算(位运算效率高),转换成字符放到字符数组中去
int index = 0;
for (byte b : byteArray) {
resultCharArray[index++] = hexDigits[b>>> 4 & 0xf];
resultCharArray[index++] = hexDigits[b& 0xf];
}
// 字符数组组合成字符串返回
return new String(resultCharArray);
}
}
PS:关于加密技术,本站还提供了如下加密工具供大家参考使用:
MD5在线加密工具:http://tools.softyun.net/password/CreateMD5Password
Escape加密/解密工具:http://tools.softyun.net/password/escapepwd
在线SHA1加密工具:http://tools.softyun.net/password/sha1encode
短链(短网址)在线生成工具:http://tools.softyun.net/password/dwzcreate
短链(短网址)在线还原工具:http://tools.softyun.net/password/unshorturl
高强度密码生成器:http://tools.softyun.net/password/CreateStrongPassword
加载全部内容