C# RSA和Java RSA互通
今天调查了C# RSA和Java RSA,网上很多人说,C#加密或者java加密 ,Java不能解密或者C#不能解密
但是我尝试了一下,发现是可以的,下面就是我尝试的代码,如果您有什么问题,我想看看,他们为什么不能互通?
- package rsa;
- import java.math.BigInteger;
- import java.security.KeyFactory;
- import java.security.PrivateKey;
- import java.security.PublicKey;
- import java.security.spec.RSAPrivateKeySpec;
- import java.security.spec.RSAPublicKeySpec;
- import javax.crypto.Cipher;
- import com.sun.org.apache.xml.internal.security.exceptions.Base64DecodingException;
- import com.sun.org.apache.xml.internal.security.utils.Base64;
- /**
- * @author cnchenhl
- * Jul 8, 2011
- */
- public class RSAMain {
- private static String module = "5m9m14XH3oqLJ8bNGw9e4rGpXpcktv9MSkHSVFVMjHbfv+SJ5v0ubqQxa5YjLN4vc49z7SVju8s0X4gZ6AzZTn06jzWOgyPRV54Q4I0DCYadWW4Ze3e+BOtwgVU1Og3qHKn8vygoj40J6U85Z/PTJu3hN1m75Zr195ju7g9v4Hk=";
- private static String exponentString = "AQAB";
- private static String delement = "vmaYHEbPAgOJvaEXQl+t8DQKFT1fudEysTy31LTyXjGu6XiltXXHUuZaa2IPyHgBz0Nd7znwsW/S44iql0Fen1kzKioEL3svANui63O3o5xdDeExVM6zOf1wUUh/oldovPweChyoAdMtUzgvCbJk1sYDJf++Nr0FeNW1RB1XG30=";
- private static String encryptString = "Vx/dGjS1YWKRubsoDgiShiwLgqyNE2z/eM65U7HZx+RogwaiZimNBxjuOS6acEhKZx66cMYEAd1fc6oewbEvDIfP44GaN9dCjKE/BkkQlwEg6aTO5q+yqy+nEGe1kvLY9EyXS/Kv1LDh3e/2xAk5FNj8Zp6oU2kq4ewL8kK/ai4=";
- /**
- * @param args
- */
- public static void main(String[] args) {
- byte[] en = encrypt();
- System.out.println(Base64.encode(en));
- byte[] enTest = null;
- try {
- enTest = Base64.decode(encryptString);
- } catch (Base64DecodingException e) {
- e.printStackTrace();
- }
- System.out.println(enTest.length);
- System.out.println(en.length);
- System.out.println(new String(Dencrypt(en)));
- System.out.println(new String(Dencrypt(enTest)));
- }
- public static byte[] encrypt() {
- try {
- byte[] modulusBytes = Base64.decode(module);
- byte[] exponentBytes = Base64.decode(exponentString);
- BigInteger modulus = new BigInteger(1, modulusBytes);
- BigInteger exponent = new BigInteger(1, exponentBytes);
- RSAPublicKeySpec rsaPubKey = new RSAPublicKeySpec(modulus, exponent);
- KeyFactory fact = KeyFactory.getInstance("RSA");
- PublicKey pubKey = fact.generatePublic(rsaPubKey);
- Cipher cipher = Cipher.getInstance("RSA");
- cipher.init(Cipher.ENCRYPT_MODE, pubKey);
- byte[] cipherData = cipher.doFinal(new String("chenhailong").getBytes());
- return cipherData;
- } catch (Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- public static byte[] Dencrypt(byte[] encrypted) {
- try {
- byte[] expBytes = Base64.decode(delement);
- byte[] modBytes = Base64.decode(module);
- BigInteger modules = new BigInteger(1, modBytes);
- BigInteger exponent = new BigInteger(1, expBytes);
- KeyFactory factory = KeyFactory.getInstance("RSA");
- Cipher cipher = Cipher.getInstance("RSA");
- RSAPrivateKeySpec privSpec = new RSAPrivateKeySpec(modules, exponent);
- PrivateKey privKey = factory.generatePrivate(privSpec);
- cipher.init(Cipher.DECRYPT_MODE, privKey);
- byte[] decrypted = cipher.doFinal(encrypted);
- return decrypted;
- } catch (Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- }
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Security.Cryptography;
- namespace RSA
- {
- class Program
- {
- static void Main(string[] args)
- {
- string de = "iBILuPJFgPMxgpbgN3F2JjD6XjcqRSApjVVbvBBEBDV21Pjj7lTrfhEjSVnJX/MVoZrmX0lxsvoXTMvvVwVF7K7W5hs7Qo+aMN96yWke7wiLEM9M4pPz60A/KSckskiona67tXcqOLXb8N18TKaNCKHv0Ce+GyEKK5+MT7e1vao=";
- //string encrypt = RSAEncrypt("", "chenhailong");
- byte[] encrypt = RSAEncrypt("chenhailong");
- //string name = RSADecrypt(encrypt);
- string name = RSADecrypt(Convert.FromBase64String(de));
- Console.WriteLine(encrypt.Length);
- Console.WriteLine(Convert.ToBase64String(encrypt));
- Console.WriteLine(name);
- Console.ReadKey();
- }
- /// <summary>
- /// RSA encrypt
- /// </summary>
- /// <param name="publickey"></param>
- /// <param name="content"></param>
- /// <returns></returns>
- public static byte[] RSAEncrypt(string content)
- {
- string publickey = @"<RSAKeyValue><Modulus>5m9m14XH3oqLJ8bNGw9e4rGpXpcktv9MSkHSVFVMjHbfv+SJ5v0ubqQxa5YjLN4vc49z7SVju8s0X4gZ6AzZTn06jzWOgyPRV54Q4I0DCYadWW4Ze3e+BOtwgVU1Og3qHKn8vygoj40J6U85Z/PTJu3hN1m75Zr195ju7g9v4Hk=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>";
- RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
- byte[] cipherbytes;
- rsa.FromXmlString(publickey);
- cipherbytes = rsa.Encrypt(Encoding.UTF8.GetBytes(content), false);
- //return Convert.ToBase64String(cipherbytes);
- return cipherbytes;
- }
- /// <summary>
- /// RSA decrypt
- /// </summary>
- /// <param name="privatekey"></param>
- /// <param name="content"></param>
- /// <returns></returns>
- public static string RSADecrypt(byte[] content)
- {
- 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>";
- RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
- byte[] cipherbytes;
- rsa.FromXmlString(privatekey);
- cipherbytes = rsa.Decrypt(content, false);
- return Encoding.UTF8.GetString(cipherbytes);
- }
- }
- }
有什么问题 请给我留言
下面是Key的互通代码
- private byte[] removeMSZero(byte[] data) {
- byte[] data1;
- int len = data.length;
- if (data[0] == 0) {
- data1 = new byte[data.length - 1];
- System.arraycopy(data, 1, data1, 0, len - 1);
- } else
- data1 = data;
- return data1;
- }
C# RSA和Java RSA互通相关推荐
- c java互通rsa_C# RSA和Java RSA互通
今天调查了C# RSA和Java RSA,网上很多人说,C#加密或者java加密 ,Java不能解密或者C#不能解密 但是我尝试了一下,发现是可以的,下面就是我尝试的代码,如果您有什么问题,我想看看, ...
- android java rsa加密_Android RSA与Java RSA加密不一样标准产生问题的解决方法
最近作一个基于android的客户端,客户端与Java服务器 (MyEclipse自带的Tomcat服务器)的通讯须要实施安全方案.而本人是使用非对称密钥来对数据进行加密的,客户端用公钥加密,服务器用 ...
- Android网络传输中必用的两个加密算法:MD5 和 RSA (附java完成测试代码)
MD5和RSA是网络传输中最常用的两个算法,了解这两个算法原理后就能大致知道加密是怎么一回事了.但这两种算法使用环境有差异,刚好互补. 一.MD5算法 首先MD5是不可逆的,只能加密而不能解密.比如明 ...
- JAVA——RSA加密【X509EncodedKeySpec、PKCS8EncodedKeySpec、RSAPublicKeySpec、RSAPrivateKeySpec】
基本概念 RSA加密算法:RSA加密算法是一种非对称加密算法.在公开密钥加密和电子商业中RSA被广泛使用.RSA是1977年由罗纳德·李维斯特(Ron Rivest).阿迪·萨莫尔(Adi Shami ...
- ras私钥c#转java_C#RSA对接JAVA中RSA方式代码实例
C#中通过FromXmlString属性加载的是XML形式,而JAVA中用到的是解析后的PEM格式的字符串,总之读取证书中信息无非是转换方式问题 /// /// c# 使用 java 的公钥进行rsa ...
- java RSA 加签验签【转】
引用自: http://blog.csdn.net/wangqiuyun/article/details/42143957/ java RSA 加签验签 package com.testdemo.co ...
- openresty 与 java RSA加解密
上一篇搞定了openresty与java之间的aes加解密.这一篇就来说说openresty与java之间RSA的加解密.在测试的过程中.发现了与aes同样的问题.就是openresty支持的填充模式 ...
- RSA加密 - Java
前言 简介 RSA公开密钥密码体制是一种使用不同的加密密钥与解密密钥,"由已知加密密钥推导出解密密钥在计算上是不可行的"密码体制. 原理 根据数论,寻求两个大素数比较简单,而将它们 ...
- 非对称加密下RSA在Java的简明教程
引言 在现实世界中,每个人都有自己的密码.在各种系统中都有各类加密和解密的需求. 本文将详细介绍一下RSA的前身后世,应用场景和在Java中的实现,从理论到实践,一步到位,触手可用. 非对称加密与对称 ...
最新文章
- 处理 Exception 的几种实践,很优雅,被很多团队采纳!
- 给小白图示讲解OFDM的原理
- PyCharm有些库(函数)没有代码提示
- 如何快速上手一款开源软件
- PHP函数之CURL: 常见问题总结
- 【深度学习】遗传算法优化GAN
- 计算机对英语口语考试成绩,英语口语考试人机对话得分技巧
- 3-1 Apache Shiro权限管理框架介绍
- 单位矩阵属性(I ^ k = I)| 使用Python的线性代数
- HDD + HDD(SSD) 多硬盘系统启动问题
- Atiitt 图像处理的常见功能业务用途与类库与功能实现 目录 1. 常见业务场景	3 1.1. 缩略图 蒙版遮罩挖空	3 1.2. 区域裁剪,水印,旋转	3 1.3. 判断图像大小分辨率要求
- 【状压dp】【POJ2288】Islands and Bridges【Hamilton路】
- c3p0 mysql 连接池配置文件_使用XML配置c3p0数据库连接池
- python京东自动下单_京东自动下单脚本
- linux磁珠技术,磁珠-china178-ChinaUnix博客
- 用Qt图形视图框架开发拼图游戏
- java3d载入obj_Threejs大型obj文件的秒加载实现
- java 判断当前月天数
- spring.xml配置类属性--喜闻乐见
- 20元充电宝 身边的炸弹?选购留意电芯
热门文章
- ionic/cordova即时通讯解决方案(上)
- dubbo接口统一异常处理的两种方式
- Nodejs中request出现ESOCKETTIMEDOUT解决方案
- vue父组件引用子组件方法显示undefined问题原因及解决方法
- 80端口被占用时的终极解决方法
- php的Allowed memory size of 134217728 bytes exhausted问题解决办法
- java 构造方法_Java构造方法和子类构造方法
- Git命令:git常用命令
- mac系统自带python开发环境吗_Mac OS搭建Python开发环境的几个误区
- 洛谷——P2077 红绿灯