本文实例讲述了java实现的MD5摘要算法。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
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中的配置:
1
2
3
4
5
|
< dependency > < groupId >commons-codec</ groupId > < artifactId >commons-codec</ artifactId > < version >1.4</ version > </ dependency > |
这里注意1.2版本和1.4版本的区别很大,因为1.4中扩展了很多方法.
具体代码如下:
1
2
3
4
5
6
7
8
9
10
|
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 ; } |
希望本文所述对大家java程序设计有所帮助。