码迷,mamicode.com
首页 > 编程语言 > 详细

Java加解密_MD5

时间:2017-10-24 13:21:20      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:补码   display   imp   包括   trace   catch   打印   oid   pen   

在Java中使用MD5摘要还是很方便的,直接上代码。

 1 package com.cxc.nothing;
 2 
 3 import java.nio.charset.Charset;
 4 import java.security.MessageDigest;
 5 
 6 public class MD5Test {
 7     public static void main(String[] args) {
 8 
 9         String text = "MD5Test";
10         try {
11             MessageDigest messageDigest = MessageDigest.getInstance("MD5");
12             byte[] md5Bytes = messageDigest.digest(text.getBytes(Charset.forName("UTF-8")));
13             for (byte b : md5Bytes) {
14                 System.out.println(b);
15             }
16         } catch (Exception e) {
17             e.printStackTrace();
18         }
19 
20     }
21 
22 }

以上代码就可以实现MD5摘要了。由于摘要的结果是字节数组,并不是我们常见的字符串,所以还有工作要做。

字节数组转字符串,还不简单,直接String str = new String(md5Bytes);结果,打印出来之后,才发现我太天真了。

然后各种百度之后,我终于知道了,原来这里的字节数组不能直接转字符串,而通常的做法是转成十六进制的数字。

MD5摘要的结果是一个128bit的大整数,

因为8bit表示一字节,所以当用字节表示的时候就会是128/8=16个字节。

因为4bit表示一个十六进制,所以当用十六进制表示的时候就会是128/4=32个十六进制数字。

如果你打印上面代码的md5Bytes,你就会看到如下的一个字节数组:

[-83, -42, -124, -31, -122, 59, 93, -112, 5, -125, 35, 104, 37, -92, 49, -62]

这里一共16个字节,而每个字节都需要拆分成两个十六进制数字。

我们先拿59来拆,这里的59是十进制的,把她写成8位的二进制0011 1011,再4位为一组转成十六进制就是3 B,所以这里的59,最后转化完就是3B。

接下来看看5,把她转成8位的二进制0000 0101,再4位为一组转成十六进制就是0 5,所以这里的5,最后转化完就是05,注意是“05”,而不是“5”。

正整数的拆分都同上,接下来就是负整数的拆分了。

接下来我们拆分-83,因为-83是负整数,所以实际存的是他的补码。求负整数的补码,将其对应正数二进制表示所有位取反(包括符号位,0变1,1变0)后加1。

先写出83的二进制表示01010011,然后取反就是10101100,再加1就是10101101,所以-83实际存储的二进制应该是1010 1101,同样4位为一组转成十六进制就是A D。

下面附上转化

技术分享
 -83-->1010 1101-->A D
 -42-->1101 0110-->D 6
-124-->1000 0100-->8 4
 -31-->1110 0001-->E 1
-122-->1000 0110-->8 6
  59-->0011 1011-->3 B
  93-->0101 1101-->5 D
-112-->1001 0000-->9 0
   5-->0000 0101-->0 5
-125-->1000 0011-->8 3
  35-->0010 0011-->2 3
 104-->0110 1000-->6 8
  37-->0010 0101-->2 5
 -92-->1010 0100-->A 4
  49-->0011 0001-->3 1
 -62-->1100 0010-->C 2
change

所以MD5摘要实际上生成的128bit是(请无视空格):1010 1101 1101 0110 1000 0100 1110 0001 1000 0110 0011 1011 0101 1101 1001 0000 0000 0101 1000 0011 0010 0011 0110 1000 0010 0101 1010 0100 0011 0001 1100 0010

最终转化成32位的十六进制表示就是ADD684E1863B5D900583236825A431C2

以上写的是转化的思路,具体的实现,网上有很多代码,这里就不贴出来了。

在完成这篇文章之前,我参考了如下资料,在此表示感谢:

http://www.cnblogs.com/renchunxiao/p/3411370.html

http://blog.csdn.net/hll174/article/details/51063689

http://blog.csdn.net/jiaomenglei/article/details/52728796

https://wenku.baidu.com/view/3145fb45ad51f01dc281f1c5.html

https://baike.baidu.com/item/%E8%A1%A5%E7%A0%81/6854613?fr=aladdin

Java加解密_MD5

标签:补码   display   imp   包括   trace   catch   打印   oid   pen   

原文地址:http://www.cnblogs.com/xiancheng/p/7722903.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!