Java和C# MD5加密比较

简介:   最近使用java 开发一个之前用C#开发的项目,当项目将要结束的时候,数据迁移出现了一个问题,那就是用户信息的迁移。之前C#版的项目是使用MD5+Base64加密的密码,加密过程太过于复杂,导致两者用户数据不能兼容。

  最近使用java 开发一个之前用C#开发的项目,当项目将要结束的时候,数据迁移出现了一个问题,那就是用户信息的迁移。之前C#版的项目是使用MD5+Base64加密的密码,加密过程太过于复杂,导致两者用户数据不能兼容。查看了很多方法,终于找到了解决方案,在此共享一下。

1.C# 加密过程处理

  (1)将字符串转化为UTF-8 格式字节数组 

代码
 1  public   byte [] GetUTF8( string  content) 
 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方式获得哈希码

代码
 1  public   byte [] GetHash( byte [] sources)
 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 将字节数组转化为字符串

代码
1  public   string  ConvertBase64( byte [] sources)
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 实现加密过程

代码
1  String s = " 111111 " ;
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版本的不同,会不会以后或之前的版本不能支持此加密方式。不过问题可以暂时解决

相关文章
|
Java 数据安全/隐私保护
Java实现最电话号码的简单加密源码
Java实现最电话号码的简单加密源码
18 0
|
4天前
|
存储 安全 网络安全
C#编程的安全性与加密技术
【4月更文挑战第21天】C#在.NET框架支持下,以其面向对象和高级特性成为安全软件开发的利器。本文探讨C#在安全加密领域的应用,包括使用System.Security.Cryptography库实现加密算法,利用SSL/TLS保障网络传输安全,进行身份验证,并强调编写安全代码的重要性。实际案例涵盖在线支付、企业应用和文件加密,展示了C#在应对安全挑战的同时,不断拓展其在该领域的潜力和未来前景。
|
16天前
|
Java 数据安全/隐私保护
java base64 加密 解密
java base64 加密 解密
|
26天前
|
编解码 算法 安全
【Java技术专题】「入门到精通系列」深入探索Java技术中常用到的六种加密技术和实现
【Java技术专题】「入门到精通系列」深入探索Java技术中常用到的六种加密技术和实现
45 0
|
1月前
|
安全 Java 数据安全/隐私保护
提升 Java 编程安全性 - 代码加密混淆工具的重要性和应用
提升 Java 编程安全性 - 代码加密混淆工具的重要性和应用
|
1月前
|
安全 小程序 Java
java实现微信服务(公众)号用户关注时,获取openid,安全模式下的加密解密实现
java实现微信服务(公众)号用户关注时,获取openid,安全模式下的加密解密实现
19 0
|
2月前
|
存储 安全 算法
【接口加密】Java中的接口加密实践
【接口加密】Java中的接口加密实践
|
2月前
|
算法 安全 Java
Java 实现 RSA 非对称加密算法-加解密和签名验签
Java 实现 RSA 非对称加密算法-加解密和签名验签
|
Java 数据安全/隐私保护
java实现加密电话号码,有具体的加密流程注释
java实现加密电话号码,有具体的加密流程注释
21 0
|
3月前
|
存储 算法 安全
3分钟快速了解使用Java进行对称加密
对称加密算法有很多种,其中较为知名的有AES(高级加密标准)、DES(数据加密标准)以及3DES(三重数据加密算法)等。这些算法在不同的场景下有着广泛的应用,为保障数据安全提供了有力支持。
61 0