`

C# RSA和Java RSA互通

    博客分类:
  • C#
 
阅读更多

今天调查了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;
    }
 
0
0
分享到:
评论
14 楼 wilsonchen 2014-06-06  
chenhailong 写道
wilsonchen 写道
chenhailong 写道
wangxiaolin3333 写道
我有一个java的公钥文件,在C#里如何解析


查看我文章下面的方法,你就知道什么原因了。。。很简单的


楼主,我也遇到同样的问题,请问文章下面的方法是指哪一篇文章呢?


就是这篇文章,下面有个方法。C#比Java多了一位,去掉就行了,我记得好像是这样的。
这篇文章都写了快2年了,有点忘记了


好的 非常感激你
13 楼 chenhailong 2014-06-06  
wilsonchen 写道
chenhailong 写道
wangxiaolin3333 写道
我有一个java的公钥文件,在C#里如何解析


查看我文章下面的方法,你就知道什么原因了。。。很简单的


楼主,我也遇到同样的问题,请问文章下面的方法是指哪一篇文章呢?


就是这篇文章,下面有个方法。C#比Java多了一位,去掉就行了,我记得好像是这样的。
这篇文章都写了快2年了,有点忘记了
12 楼 wilsonchen 2014-06-06  
chenhailong 写道
wangxiaolin3333 写道
我有一个java的公钥文件,在C#里如何解析


查看我文章下面的方法,你就知道什么原因了。。。很简单的


楼主,我也遇到同样的问题,请问文章下面的方法是指哪一篇文章呢?
11 楼 chenhailong 2014-04-24  
wangxiaolin3333 写道
我有一个java的公钥文件,在C#里如何解析


查看我文章下面的方法,你就知道什么原因了。。。很简单的
10 楼 wangxiaolin3333 2014-04-23  
我有一个java的公钥文件,在C#里如何解析
9 楼 chenhailong 2011-12-27  
piziqie 写道
楼主,我遇到个问题。 C#端提供的公钥,我要在java端加密,然后再到C#端验证。 C#端的公钥怎样转换为java端公钥啊?毫无头绪.费力. 5555555  


嘿嘿,别担心
我下面给你的方法就可以解决的
你仔细看看就知道了
在说公钥怎么能互相转化那?
这个我就不太清楚了
我想能可供给你一个建议
1.先在C#中加密,在将加密字段提供给java,java进行一些操作
2.然后java出来,进到C#中,将加密字段中给C#解密就OK了
3.必要点:C#公钥,C#私钥 即可,至于java只是做传输作用罢了
8 楼 piziqie 2011-12-27  
楼主,我遇到个问题。 C#端提供的公钥,我要在java端加密,然后再到C#端验证。 C#端的公钥怎样转换为java端公钥啊?毫无头绪.费力. 5555555  
7 楼 chenhailong 2011-11-04  
ltcszk 写道
C#的加密算法有长度限制的超过110就会报错

请在仔细研究一下,c#可以最大是128位的。
6 楼 ltcszk 2011-11-03  
C#的加密算法有长度限制的超过110就会报错
5 楼 leemans 2011-09-09  
polim 写道
@"<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>

这段字符串 怎么生成的?


同问, 这个字符串到底怎么生成的?
4 楼 polim 2011-08-15  
@"<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>

这段字符串 怎么生成的?
3 楼 chenhailong 2011-07-11  
bzaxhj 写道
正准备尝试这按你说的这个试试,却出现了这样的问题,导入语句报错。Base64不认识

应该不会吧,我是没导入包的,你在尝试一下,看看基本上sun的包,应该没问题的
2 楼 bzaxhj 2011-07-11  
正准备尝试这按你说的这个试试,却出现了这样的问题,导入语句报错。Base64不认识
1 楼 bzaxhj 2011-07-11  
你好,
import com.sun.org.apache.xml.internal.security.exceptions.Base64DecodingException;  
import com.sun.org.apache.xml.internal.security.utils.Base64;

我的internal下面没有security,请问是否需要额外导入什么jar包?

相关推荐

    C#RSA加密与JAVA解密,实现相互通信

    "C# RSA加密与JAVA解密,实现相互通信"的主题聚焦于如何利用RSA公钥/私钥加密算法在C#和Java两个不同的编程环境中实现安全的数据交换。RSA是一种非对称加密算法,它使用一对密钥——公钥和私钥,公钥用于加密,私钥...

    C#和Java实现互通的RSA&DES加解密算法

    本话题主要关注如何在C#和Java之间通过RSA和DES加密算法实现数据的安全互通。RSA是一种非对称加密算法,适用于小量数据加密,如密钥交换;而DES是对称加密算法,适合大量数据的快速加密,但安全性相对较低。 首先,...

    RSA加密算法实现以及C#与java互通加解密

    ### RSA加密算法实现以及C#与Java互通加解密 #### 一、RSA算法简介 RSA算法是一种非对称加密算法,由Ron Rivest、Adi Shamir 和 Leonard Adleman 在1977年提出,并以其三人的名字首字母命名。RSA算法的安全性基于...

    C# 实现与JAVA互通 加签/验签,RSA加密/解密

    * RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。  * RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。  * RSA加密解密:私钥...

    C#与java平台RSA加密解密签名验签互通案例

    本案例聚焦于"C#与Java平台RSA加密解密签名验签互通"的问题,这涉及到两个主要的技术点:RSA加密算法和跨平台兼容性。下面将详细阐述这两个知识点。 首先,RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和...

    C#和Java关于RSA非对称加密互通类

    在C#和Java之间进行RSA互通时,需要解决的主要问题就是密钥格式的转换。由于C#默认使用XML格式,而Java更倾向于PEM或Base64格式,我们需要将这些格式相互转换。这通常涉及到Base64解码、XML解析和字节数组操作。 ...

    C#Android互通RSA加密解密

    在提供的文件列表中,"51Aspx源码必读.txt"可能包含了一些与RSA加密解密相关的代码示例或者最佳实践,"Test.sln"是一个C#项目解决方案,可能包含了实现RSA互通的C#代码。"Javaworkspace"可能是Android开发的工作空间...

    RSA+AES C# .net版本已经与java,js等语言对接均可以互通

    在给定的标题和描述中,提到了两种主要的加密算法:RSA和AES,并且强调了这些C#实现的加密方法已经与其他编程语言(如Java和JavaScript)实现了互通。下面将详细阐述这两种加密算法以及它们在实际应用中的使用。 ...

    RSA算法Android C#互通

    在“RSA算法Android C#互通”这个场景下,Android设备和C#服务器需要能够互相识别并正确处理对方通过RSA算法加密的数据。以下是这个过程中的关键知识点: 1. **公钥/私钥生成**:首先,Android端或C#端需要生成一对...

    .net与Java互通的RSA公钥加密公钥解密(X509格式证书),支持分段加密

    有朋友叫帮忙做有一个RSA加解密的帮助类,...由于C#RSA只支持公钥加密,私钥解密。而现在只能使用公钥加密,公钥解密,而且C#与Java并不互通,所以采用第三方类库 BouncyCastle来进行实现。并且实现了分段加密功能。

    RSA算法,C#与java互通demo模块核心代码

    在C#和Java这两种不同的编程语言中实现RSA互通,通常需要处理的关键点包括密钥对的生成、密钥的序列化与反序列化、以及正确的加解密过程。以下是这些关键点的详细说明: 1. **密钥对生成**:RSA算法首先需要生成...

    Java RSA加密 与.net 的密匙转换完整版,java类

    本资源提供的"Java RSA加密与.NET的密匙转换完整版,java类"解决了这个问题,实现了Java RSA密钥对到C#格式的转换,确保了跨平台的互通性。 `RsaHelper.java`是这个解决方案的核心文件,它可能包含了以下关键功能:...

    RSA-encryption-between-CSharp-and-java.rar_between_rsa_rsa cshar

    C#和Java之间的RSA互通主要涉及到密钥的交换和编码格式的统一。由于两个平台的密钥表示方式可能存在差异,通常需要将密钥转换为标准格式,如Base64编码。此外,对于加密的数据,两个平台可能使用不同的填充模式或...

    Delphi(delphi7-XE)标准RSA加密,解密,签名.与C,Java,php等通用

    本篇文章将深入探讨Delphi (从delphi7到XE版本)中的RSA实现,以及如何与其他编程语言如C、Java、PHP进行跨平台的加解密和签名操作。 1. RSA原理: RSA基于数论中的大数因子分解难题,由Ron Rivest、Adi Shamir和...

    RSA小程序项目加解密

    RSA是由Ron Rivest、Adi Shamir和Leonard Adleman三位科学家于1977年提出的,它基于大数因子分解的数学难题。该算法包含两个密钥:公钥和私钥。公钥可以公开给任何人,用于加密数据;而私钥则需要保密,用于解密数据...

    c/c++与java互通 AES加密解密

    此外,为了确保互通性,必须确保在C/C++和Java中都使用相同的标准和模式(如ECB、CBC、CFB等)以及填充方式(如PKCS7)。这些细节如果不匹配,可能会导致加密解密失败。 在实际项目中,这种做法虽然可以锻炼基础...

    同时兼容JS和C#的RSA加密解密算法详解(对web提交的数据加密传输)

    web应用中,前端的数据处理和交互基本上都是靠javascript来完成,后台的逻辑处理可以C#(java)等进行处理。 微软的C#中虽然有RSA算法,但是格式和OpenSSL生成的公钥/私钥文件格式并不兼容。这个也给贯通前后台的RSA...

    私钥加密公钥解密JAVA、C#、PHP互通

    在Java、C#和PHP这三种编程语言中,实现私钥加密和公钥解密的关键库分别是Java的Java Cryptography Extension (JCE),C#的System.Security.Cryptography库,以及PHP的OpenSSL扩展。下面将分别介绍这三个平台如何实现...

    Rsa 私钥加密 公钥解密

    这个压缩包文件的标题和描述提及了“Rsa 私钥加密 公钥解密”,这意味着我们将探讨如何使用RSA算法进行私钥加密和公钥解密的过程,以及在不同编程语言如JAVA、C#、PHP之间的互通性。 首先,RSA加密的基础是大数因子...

    Delphi XE2+与Java互通3Des加解密方法

    使用的是Chilkat Delphi DLL,经过测试仅实现了3DES中ECB加密模式,填充方式为pkcs5pading的加解密,加密后的内容可用在线3DES加...所以可以与Java,C#等其他语言实现互通加解密。 附件为DLL类库源码及调用方法和说明

Global site tag (gtag.js) - Google Analytics