Расшифровывать байты в asp.net - PullRequest
1 голос
/ 22 января 2011

Ниже приведен код моего Java-апплета

KeyFactory keyFactory = KeyFactory.getInstance("RSA");
byte[] privKeyBytes = loadPriavteKeyFromFile(fileName, new String(txtPassword.getPassword()));
PKCS8EncodedKeySpec privSpec = new PKCS8EncodedKeySpec(privKeyBytes);
RSAPrivateKey privKey = (RSAPrivateKey) keyFactory.generatePrivate(privSpec);
Cipher rsaCipher = Cipher.getInstance("RSA");
rsaCipher.init(Cipher.ENCRYPT_MODE, privKey);
byte[] ciphertext = null;
ciphertext = rsaCipher.doFinal(xmlToSign.getBytes());
String urlString = "http://localhost:3290/SignApplet.aspx";
String senddata  = Base64.encodeBase64String(ciphertext);
doHttpUrlConnectionAction(urlString,senddata.getBytes());
JOptionPane.showMessageDialog(this, "XML successfully signed and sent to server.");

на стороне сервера я тоже пытаюсь расшифровать байт с помощью открытого ключа

byte[] b;
b = Request.BinaryRead(178);
string encodedbytes = new System.Text.UTF8Encoding().GetString(b);
b = Convert.FromBase64String(encodedbytes);
Debug.WriteLine("decrypted bytes:" + new System.Text.UTF8Encoding().GetString(b));
// The path to the certificate.
string Certificate = @"c:\certs\lafa801114sd3.cer";

//// Load the certificate into an X509Certificate object.
X509Certificate cert = new X509Certificate(Certificate);
RSACryptoServiceProvider publicprovider = (RSACryptoServiceProvider)CertUtil.GetCertPublicKey(cert);
byte[] decbytes = publicprovider.Decrypt(b, false);
Debug.WriteLine("decrypted bytes" + new System.Text.UTF8Encoding().GetString(decbytes));

Может ли кто-нибудь помочь в следующем исключении, которое я получаю в byte[] decbytes = publicprovider.Decrypt(b, false); строке

Первое случайное исключение типа «System.Security.Cryptography.CryptographicException» произошло в mscorlib.dll Ключ не существует.

и сертификат не установлен в хранилище ключей nay. Также я могу успешно расшифровать данные с помощью сервлета Java.

я использую asp.net vs2010 на windows 7 открытый и закрытый ключи хранятся в отдельных файлах

1 Ответ

2 голосов
/ 22 января 2011

Вот несколько статей, которые могут вам помочь: Java RSA Encrypt - Decrypt .NET (что похоже на то, что вы ищете) и http://www.jensign.com/JavaScience/dotnet/RSAEncrypt/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...