java实现的MD5摘要算法完整实例
|
本文实例讲述了java实现的MD5摘要算法。分享给大家供大家参考,具体如下:
package com.soufun.com;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
/**
* @author WHD
*/
public class MD5Test {
// MD5 单向加密
public static void main(String[] args) throws NoSuchAlgorithmException,UnsupportedEncodingException {
String str = "hellomd摘要算法开始";
System.out.println("原始值" + str);
System.out.println("加密后的" + MD5Test.afterMD5(str));
String digest = MD5Test.afterMD5(str);
System.out.println(digest.equals(MD5Test.afterMD5(str)));
}
public static String afterMD5(String str) throws NoSuchAlgorithmException,UnsupportedEncodingException {
// 获取MD5 加密对象,还可以获取SHA加密对象
MessageDigest md5 = MessageDigest.getInstance("MD5");
// 将输入的信息使用指定的编码方式获取字节
byte[] bytes = str.getBytes("UTF-8");
// 使用md5 类来获取摘要,也就是加密后的字节
md5.update(bytes);
byte[] md5encode = md5.digest();
StringBuffer buffer = new StringBuffer();
for (int i = 0; i < md5encode.length; i++) {
// 使用&0xff 不足24高位,因为只占了8低位
int val = ((int) md5encode[i]) & 0xff;
if (val < 16) {
buffer.append("0");
}
// 以十六进制(基数 16)无符号整数形式返回一个整数参数的字符串表示形式。
buffer.append(Integer.toHexString(val));
}
return buffer.toString();
}
}
使用org.apache.commons.codec.digest.DigestUtilsorg.apache.commons.codec.digest.DigestUtils来实现md5加密 在maven中的配置: <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.4</version> </dependency> 这里注意1.2版本和1.4版本的区别很大,因为1.4中扩展了很多方法.
public static String afterMd5(String str){
try {
String md5 = DigestUtils.md5Hex(str.getBytes("UTF-8"));
return md5;
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具: 密码安全性在线检测: 高强度密码生成器: 迅雷、快车、旋风URL加密/解密工具: 在线散列/哈希算法加密工具: 在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具: 在线sha1/sha224/sha256/sha384/sha512加密工具: 希望本文所述对大家java程序设计有所帮助。 (编辑:鄂州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
