C#加密转换为Java的加密 在本篇资源中,我们将讨论C#的加密转换为Java的加密,特别是MD5加密的实现。在C#中,我们使用MD5CryptoServiceProvider类来实现MD5加密,而在Java中,我们使用MessageDigest类来实现MD5加密。下面,我们将详细介绍这两种实现方式的区别和联系。 C#中MD5加密的实现 在C#中,我们使用MD5CryptoServiceProvider类来实现MD5加密。该类提供了ComputeHash方法,该方法可以将输入的字符串转换为字节数组,然后计算其MD5摘要。下面是一个示例代码: ```csharp public static string GetMD5String(string myString) { MD5 md5 = new MD5CryptoServiceProvider(); byte[] fromData = System.Text.Encoding.Unicode.GetBytes(myString); byte[] targetData1 = md5.ComputeHash(fromData); byte[] targetData2 = md5.ComputeHash(targetData1); byte[] targetData = md5.ComputeHash(targetData2); string byte2String = ""; for (int i = 0; i < targetData.Length; i++) { int a = targetData[i]; int v = a % 24 + 65; byte2String += (char)v; } return byte2String; } ``` 在上面的代码中,我们首先使用System.Text.Encoding.Unicode.GetBytes方法将输入的字符串转换为字节数组,然后使用MD5CryptoServiceProvider类的ComputeHash方法计算其MD5摘要。我们将MD5摘要转换为十六进制的字符串形式。 Java中MD5加密的实现 在Java中,我们使用MessageDigest类来实现MD5加密。该类提供了getInstance方法,该方法可以获取MD5摘要算法的实例对象。下面是一个示例代码: ```java public final static String MD5(String s) { try { byte[] btInput = s.getBytes("utf-8"); byte[] source = new byte[btInput.length * 2]; for (int i = 1, j = 0; i <= source.length; i++) { if (i % 2 == 0) source[i - 1] = 0; else { source[i - 1] = btInput[j]; j++; } } MessageDigest mdInst = MessageDigest.getInstance("MD5"); mdInst.update(source); byte[] md = mdInst.digest(); mdInst.update(md); md = mdInst.digest(); mdInst.update(md); md = mdInst.digest(); StringBuilder byte2String = new StringBuilder(); for (int i = 0; i < 16; i++) { int byte0 = md[i]; if (byte0 < 0) { byte0 = byte0 + 256; } int v = byte0 % 24 + 65; byte2String.append((char) v); } return byte2String.toString(); } catch (Exception e) { e.printStackTrace(); return null; } } ``` 在上面的代码中,我们首先使用getBytes方法将输入的字符串转换为字节数组,然后使用MessageDigest类的getInstance方法获取MD5摘要算法的实例对象。我们将MD5摘要转换为十六进制的字符串形式。 C#和Java中字符串编码的区别 在C#和Java中,字符串编码的方式不同。C#使用System.Text.Encoding类来实现字符串编码,而Java使用getBytes方法来实现字符串编码。下面是一个示例代码: ```csharp // C# string str = "我是中国人"; byte[] result = System.Text.Encoding.UTF8.GetBytes(str); ``` ```java // Java String str = "我是中国人"; byte[] result = str.getBytes("utf-8"); ``` 在上面的代码中,我们可以看到C#使用System.Text.Encoding.UTF8.GetBytes方法将字符串转换为字节数组,而Java使用getBytes方法将字符串转换为字节数组。但是,这两种方法的输出结果不同。C#的输出结果为[230, 136, 145, 230, 152, 175,...],而Java的输出结果为[-26, -120, -111, -26, -104, -81, -28, -72, -83, -27, -101, -67, -28, -70, -70]。 总结 在本篇资源中,我们讨论了C#和Java中MD5加密的实现方式,并比较了这两种实现方式的区别。我们还讨论了C#和Java中字符串编码的区别,了解了这两种语言中字符串编码的方式和输出结果的差异。
- 粉丝: 0
- 资源: 7
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助