Java和C# MD5加密比较
2009-12-11 14:40 贺臣 阅读(11080) 评论(0) 编辑 收藏 举报最近使用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版本的不同,会不会以后或之前的版本不能支持此加密方式。不过问题可以暂时解决
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架