最近使用java 开发一个之前用C#开发的项目,当项目将要结束的时候,数据迁移出现了一个问题,那就是用户信息的迁移。之前C#版的项目是使用MD5+Base64加密的密码,加密过程太过于复杂,导致两者用户数据不能兼容。查看了很多方法,终于找到了解决方案,在此共享一下。
1.C# 加密过程处理
(1)将字符串转化为UTF-8 格式字节数组
2 {
3 byte[] bytes = Encoding.UTF8.GetBytes(content);
4 foreach (byte b in bytes)
5 {
6 Console.Write(b);
7 }
8 Console.WriteLine("\n");
9 return bytes;
10 }
这里是将一个字符串用UTF-8的编码方式转换为字节数组,这是加密处理的第一步,和java的UTF-8编码处理结果没有什么不同。
(2) 将字节数组用MD5方式获得哈希码
2 {
3 MD5CryptoServiceProvider MD5CSP = new MD5CryptoServiceProvider();
4 byte[] targets = MD5CSP.ComputeHash(sources);
5 foreach (byte b in targets)
6 {
7 Console.Write(b.ToString("x2"));
8 }
9 Console.WriteLine("\n");
10 return targets;
11 }
这里是处理加密的关键过程。ComputeHash 哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。数据的少量更改会在哈希值中产生不可预知的大量更改。
这个过程是通过MD5中的ComputeHash方法获得第一个步骤处理的字节数组的哈希值
(3) 使用Base64 将字节数组转化为字符串
2 {
3 string value = Convert.ToBase64String(sources);
4 Console.WriteLine(value);
5 Console.WriteLine("\n");
6 return value;
7 }
这个方式很简单不用多说。经过以上三个步骤就可以得到加密结果。现在就是想用Java实现上面的过程。其难点就是java对MD5加密过程的处理在得到哈希值的时候不明确,我在用Spring 中的加密时都不能正确得到结果。查找了很多资料,终于解决了这个问题(其实很简单)。
2. java 实现加密过程
2 MessageDigest md5 = MessageDigest.getInstance("MD5");
3 sun.misc.BASE64Encoder baseEncoder = new sun.misc.BASE64Encoder();
4 String value=baseEncoder.encode(md5.digest(s.getBytes("utf-8")));
5 System.out.println(value);
java的jdk 中其实就自带了这种加密方式,不过可能考虑到jdk版本的不同,会不会以后或之前的版本不能支持此加密方式。不过问题可以暂时解决