今天调查了C# RSA和Java RSA,网上很多人说,C#加密或者java加密 ,Java不能解密或者C#不能解密

但是我尝试了一下,发现是可以的,下面就是我尝试的代码,如果您有什么问题,我想看看,他们为什么不能互通?

  1. package rsa;
  2. import java.math.BigInteger;
  3. import java.security.KeyFactory;
  4. import java.security.PrivateKey;
  5. import java.security.PublicKey;
  6. import java.security.spec.RSAPrivateKeySpec;
  7. import java.security.spec.RSAPublicKeySpec;
  8. import javax.crypto.Cipher;
  9. import com.sun.org.apache.xml.internal.security.exceptions.Base64DecodingException;
  10. import com.sun.org.apache.xml.internal.security.utils.Base64;
  11. /**
  12. * @author cnchenhl
  13. * Jul 8, 2011
  14. */
  15. public class RSAMain {
  16. private static String module = "5m9m14XH3oqLJ8bNGw9e4rGpXpcktv9MSkHSVFVMjHbfv+SJ5v0ubqQxa5YjLN4vc49z7SVju8s0X4gZ6AzZTn06jzWOgyPRV54Q4I0DCYadWW4Ze3e+BOtwgVU1Og3qHKn8vygoj40J6U85Z/PTJu3hN1m75Zr195ju7g9v4Hk=";
  17. private static String exponentString = "AQAB";
  18. private static String delement = "vmaYHEbPAgOJvaEXQl+t8DQKFT1fudEysTy31LTyXjGu6XiltXXHUuZaa2IPyHgBz0Nd7znwsW/S44iql0Fen1kzKioEL3svANui63O3o5xdDeExVM6zOf1wUUh/oldovPweChyoAdMtUzgvCbJk1sYDJf++Nr0FeNW1RB1XG30=";
  19. private static String encryptString = "Vx/dGjS1YWKRubsoDgiShiwLgqyNE2z/eM65U7HZx+RogwaiZimNBxjuOS6acEhKZx66cMYEAd1fc6oewbEvDIfP44GaN9dCjKE/BkkQlwEg6aTO5q+yqy+nEGe1kvLY9EyXS/Kv1LDh3e/2xAk5FNj8Zp6oU2kq4ewL8kK/ai4=";
  20. /**
  21. * @param args
  22. */
  23. public static void main(String[] args) {
  24. byte[] en = encrypt();
  25. System.out.println(Base64.encode(en));
  26. byte[] enTest = null;
  27. try {
  28. enTest = Base64.decode(encryptString);
  29. } catch (Base64DecodingException e) {
  30. e.printStackTrace();
  31. }
  32. System.out.println(enTest.length);
  33. System.out.println(en.length);
  34. System.out.println(new String(Dencrypt(en)));
  35. System.out.println(new String(Dencrypt(enTest)));
  36. }
  37. public static byte[] encrypt() {
  38. try {
  39. byte[] modulusBytes = Base64.decode(module);
  40. byte[] exponentBytes = Base64.decode(exponentString);
  41. BigInteger modulus = new BigInteger(1, modulusBytes);
  42. BigInteger exponent = new BigInteger(1, exponentBytes);
  43. RSAPublicKeySpec rsaPubKey = new RSAPublicKeySpec(modulus, exponent);
  44. KeyFactory fact = KeyFactory.getInstance("RSA");
  45. PublicKey pubKey = fact.generatePublic(rsaPubKey);
  46. Cipher cipher = Cipher.getInstance("RSA");
  47. cipher.init(Cipher.ENCRYPT_MODE, pubKey);
  48. byte[] cipherData = cipher.doFinal(new String("chenhailong").getBytes());
  49. return cipherData;
  50. } catch (Exception e) {
  51. e.printStackTrace();
  52. }
  53. return null;
  54. }
  55. public static byte[] Dencrypt(byte[] encrypted) {
  56. try {
  57. byte[] expBytes = Base64.decode(delement);
  58. byte[] modBytes = Base64.decode(module);
  59. BigInteger modules = new BigInteger(1, modBytes);
  60. BigInteger exponent = new BigInteger(1, expBytes);
  61. KeyFactory factory = KeyFactory.getInstance("RSA");
  62. Cipher cipher = Cipher.getInstance("RSA");
  63. RSAPrivateKeySpec privSpec = new RSAPrivateKeySpec(modules, exponent);
  64. PrivateKey privKey = factory.generatePrivate(privSpec);
  65. cipher.init(Cipher.DECRYPT_MODE, privKey);
  66. byte[] decrypted = cipher.doFinal(encrypted);
  67. return decrypted;
  68. } catch (Exception e) {
  69. e.printStackTrace();
  70. }
  71. return null;
  72. }
  73. }
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Security.Cryptography;
  6. namespace RSA
  7. {
  8. class Program
  9. {
  10. static void Main(string[] args)
  11. {
  12. string de  = "iBILuPJFgPMxgpbgN3F2JjD6XjcqRSApjVVbvBBEBDV21Pjj7lTrfhEjSVnJX/MVoZrmX0lxsvoXTMvvVwVF7K7W5hs7Qo+aMN96yWke7wiLEM9M4pPz60A/KSckskiona67tXcqOLXb8N18TKaNCKHv0Ce+GyEKK5+MT7e1vao=";
  13. //string encrypt = RSAEncrypt("", "chenhailong");
  14. byte[] encrypt = RSAEncrypt("chenhailong");
  15. //string name = RSADecrypt(encrypt);
  16. string name = RSADecrypt(Convert.FromBase64String(de));
  17. Console.WriteLine(encrypt.Length);
  18. Console.WriteLine(Convert.ToBase64String(encrypt));
  19. Console.WriteLine(name);
  20. Console.ReadKey();
  21. }
  22. /// <summary>
  23. /// RSA encrypt
  24. /// </summary>
  25. /// <param name="publickey"></param>
  26. /// <param name="content"></param>
  27. /// <returns></returns>
  28. public static byte[] RSAEncrypt(string content)
  29. {
  30. string publickey = @"<RSAKeyValue><Modulus>5m9m14XH3oqLJ8bNGw9e4rGpXpcktv9MSkHSVFVMjHbfv+SJ5v0ubqQxa5YjLN4vc49z7SVju8s0X4gZ6AzZTn06jzWOgyPRV54Q4I0DCYadWW4Ze3e+BOtwgVU1Og3qHKn8vygoj40J6U85Z/PTJu3hN1m75Zr195ju7g9v4Hk=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>";
  31. RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
  32. byte[] cipherbytes;
  33. rsa.FromXmlString(publickey);
  34. cipherbytes = rsa.Encrypt(Encoding.UTF8.GetBytes(content), false);
  35. //return Convert.ToBase64String(cipherbytes);
  36. return cipherbytes;
  37. }
  38. /// <summary>
  39. /// RSA decrypt
  40. /// </summary>
  41. /// <param name="privatekey"></param>
  42. /// <param name="content"></param>
  43. /// <returns></returns>
  44. public static string RSADecrypt(byte[] content)
  45. {
  46. string privatekey = @"<RSAKeyValue><Modulus>5m9m14XH3oqLJ8bNGw9e4rGpXpcktv9MSkHSVFVMjHbfv+SJ5v0ubqQxa5YjLN4vc49z7SVju8s0X4gZ6AzZTn06jzWOgyPRV54Q4I0DCYadWW4Ze3e+BOtwgVU1Og3qHKn8vygoj40J6U85Z/PTJu3hN1m75Zr195ju7g9v4Hk=</Modulus><Exponent>AQAB</Exponent><P>/hf2dnK7rNfl3lbqghWcpFdu778hUpIEBixCDL5WiBtpkZdpSw90aERmHJYaW2RGvGRi6zSftLh00KHsPcNUMw==</P><Q>6Cn/jOLrPapDTEp1Fkq+uz++1Do0eeX7HYqi9rY29CqShzCeI7LEYOoSwYuAJ3xA/DuCdQENPSoJ9KFbO4Wsow==</Q><DP>ga1rHIJro8e/yhxjrKYo/nqc5ICQGhrpMNlPkD9n3CjZVPOISkWF7FzUHEzDANeJfkZhcZa21z24aG3rKo5Qnw==</DP><DQ>MNGsCB8rYlMsRZ2ek2pyQwO7h/sZT8y5ilO9wu08Dwnot/7UMiOEQfDWstY3w5XQQHnvC9WFyCfP4h4QBissyw==</DQ><InverseQ>EG02S7SADhH1EVT9DD0Z62Y0uY7gIYvxX/uq+IzKSCwB8M2G7Qv9xgZQaQlLpCaeKbux3Y59hHM+KpamGL19Kg==</InverseQ><D>vmaYHEbPAgOJvaEXQl+t8DQKFT1fudEysTy31LTyXjGu6XiltXXHUuZaa2IPyHgBz0Nd7znwsW/S44iql0Fen1kzKioEL3svANui63O3o5xdDeExVM6zOf1wUUh/oldovPweChyoAdMtUzgvCbJk1sYDJf++Nr0FeNW1RB1XG30=</D></RSAKeyValue>";
  47. RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
  48. byte[] cipherbytes;
  49. rsa.FromXmlString(privatekey);
  50. cipherbytes = rsa.Decrypt(content, false);
  51. return Encoding.UTF8.GetString(cipherbytes);
  52. }
  53. }
  54. }

有什么问题 请给我留言

下面是Key的互通代码

  1. private byte[] removeMSZero(byte[] data) {
  2. byte[] data1;
  3. int len = data.length;
  4. if (data[0] == 0) {
  5. data1 = new byte[data.length - 1];
  6. System.arraycopy(data, 1, data1, 0, len - 1);
  7. } else
  8. data1 = data;
  9. return data1;
  10. }

C# RSA和Java RSA互通的更多相关文章

  1. RSA算法 Android JAVA C#互通

    RSA算法属非对称加密算法,在实际使用中,往往客户端使用公钥进行加密传递敏感数据,服务端server使用私钥进行解密,这样防止中间人从网络获取敏感数据的明文. Android端主要代码如下: pack ...

  2. C# 与 Java Rsa加密与解密互通

    Rsa 加密标准的制定已经过去了十多年了. 这两天在看rsa 加密的文章,基本上都是在说 .net 与 java 之间的 rsa加密是不能互通的.因为项目有用到,所以花了点时间对rsa加密做了一点点了 ...

  3. RSA密钥,JAVA与.NET之间转换

    最近在做银联的一个接口,用到RSA签名,悲剧来了,.net用的RSA密钥格式和JAVA用的不一样 .net为XML格式 <RSAKeyValue><Modulus>53Knuj ...

  4. Android网络传输中必用的两个加密算法:MD5 和 RSA (附java完成测试代码)

    MD5和RSA是网络传输中最常用的两个算法,了解这两个算法原理后就能大致知道加密是怎么一回事了.但这两种算法使用环境有差异,刚好互补. 一.MD5算法 首先MD5是不可逆的,只能加密而不能解密.比如明 ...

  5. Android网络传输中必用的两个加密算法:MD5 和 RSA (附java完毕測试代码)

    MD5和RSA是网络传输中最经常使用的两个算法,了解这两个算法原理后就能大致知道加密是怎么一回事了.但这两种算法使用环境有差异,刚好互补. 一.MD5算法 首先MD5是不可逆的,仅仅能加密而不能解密. ...

  6. JAVA RSA非对称加密详解[转载]

    一.概述1.RSA是基于大数因子分解难题.目前各种主流计算机语言都支持RSA算法的实现2.java6支持RSA算法3.RSA算法可以用于数据加密和数字签名4.RSA算法相对于DES/AES等对称加密算 ...

  7. java RSA 加签验签【转】

    引用自: http://blog.csdn.net/wangqiuyun/article/details/42143957/ java RSA 加签验签 package com.testdemo.co ...

  8. C#-java RSA加密解密

    using Org.BouncyCastle.Math; using Org.BouncyCastle.Crypto.Parameters; using Org.BouncyCastle.Securi ...

  9. java rsa 解密报:javax.crypto.BadPaddingException: Decryption error

    Exception in thread "main" javax.crypto.BadPaddingException: Decryption error    at sun.se ...

随机推荐

  1. 5. Fragment详解

    onCreateView是Fragment生命周期方法中最重要的一个.因为在该 方法中会创建在Fragment中显示的View. public View onCreateView(LayoutInfl ...

  2. OSX 10.10安装教程。

    现在苹果已经放出了OS X 10.9 Mavericks第一个开发者预览版,从Mac App Store中获得的安装程序,可以在10.8的系统中直接进行升级,原有文件都会保留.但是要想制作成一个10. ...

  3. .NET异步编程初识async与await

    这是两个关键字,用于异步编程.我们传统的异步编程方式一般是Thread.ThreadPool.BeginXXX.EndXXX等等.把调用.回调分开来,代码的逻辑是有跳跃的,于是会导致思路不是很清晰的问 ...

  4. Hive QL

    转自http://www.alidata.org/archives/581 Hive 的官方文档中对查询语言有了很详细的描述,请参考:http://wiki.apache.org/hadoop/Hiv ...

  5. 图解WPF程序打包全过程

    首先打开已经完成的工程,如图: 下面开始制作安装程序包. 第一步:[文件]——[新建]——[项目]——安装项目. 名称——可以自己根据要求修改. 位置——是指你要制作的安装文件存放在什么目录内,可以根 ...

  6. 记录一个 关于 python 普通方法,静态方法和类方法 的介绍。@classmethod @staticmethod

    上班时间 只贴看到最厉害的答案 回头总结 http://stackoverflow.com/questions/12179271/python-classmethod-and-staticmethod ...

  7. 数据库 CHECKDB 发现了x个分配错误和 x 个一致性错误

    --1.在SQL查询分析器中执行以下语句:(注以下所用的POS为数据库名称,请用户手工改为自己的数据库名) use pos dbcc checkdb --2.查看查询结果,有很多红色字体显示,最后结果 ...

  8. 第三百零八至三百二十天 how can I 坚持

    十三天..2月4号至2月16号,好快,假期还没开始就结束了.一一回忆下. 2月4号,腊月二十六,最后一天上班,没多大事,好像是玩了一天,东月回家,貌似路上好折腾,晚上D401,和她聊了一路,也聊了好多 ...

  9. ApplicationIdle

    ApplicationIdle 不忙的时候调用此事件 ::Fmx::Forms::Application->OnIdle = ApplicationIdle; void __fastcall T ...

  10. Latex 横排图片

    \begin{figure} \begin{minipage}[t]{0.5\linewidth} \centering \includegraphics[width=2.2in]{figure/an ...