Pergunta

Eu estou usando um certificado gerado pelo makecert que tem tanto a chave privada e pública. O lado java usa essa chave pública para criptografar os dados e .net decifra-lo de volta.

Eu estou tentando descriptografar criptografado string codificada de 64 bits do Java e recebendo dados errados.

Para ver se tudo é bom final on.Net, eu Frist tentou criptografar com a chave pública e, em seguida, descriptografar com a iniciativa privada usando o mesmo certificado. Meus olhares código como este.

X509Certificate2 cert = GetCert(key, StoreName.My, StoreLocation.LocalMachine);
RSACryptoServiceProvider provider =  (RSACryptoServiceProvider)cert.PrivateKey;

RSACryptoServiceProvider publicprovider = (RSACryptoServiceProvider)cert.PublicKey.Key;

if (cert.HasPrivateKey)
    MessageBox.Show("Got private key");

byte[] encrypted = publicprovider.Encrypt(Encoding.UTF8.GetBytes(text), false);
byte[] decryptedBytes = provider.Decrypt(encrypted, false); 

Mesmo aqui eu estou recebendo o erro. Estou faltando alguma coisa?

O certificado parece válido com tanto pública e uma chave privada.

Foi útil?

Solução 4

Eu finalmente encontrei o problema. Eu não estava colocando a chave para MakeCert para defini-lo como chave RSA Crypto.

Outras dicas

Eu tive o mesmo problema com um certificado auto-assinado, o problema foi que eu estava gerando o certificado com o -sky signature interruptor em vez de -sky exchange (você usa a assinatura para a assinatura e troca de encriptação / desencriptação)

Aqui é meu comando completo para MakeCert que as obras:

makecert -r -pe -a sha1 -n "CN=MyName" -ss my -sr CurrentUser -sky exchange

O código a seguir funciona bem para mim:

        RSACryptoServiceProvider privateKey = new RSACryptoServiceProvider();
        privateKey.FromXmlString("<RSAKeyValue><Modulus>wL8s+C8SnnlaaqR+VsyijmxOJOARNa4o7ZNsqfy3+9J9Ol2JNSjjMfQWoUnFtClzJBlZhU5KtuazQe8ZKXTX9YvKoJdRhlsonZkC04qiTMdO/FZIH00GrCRxeQ7XDnQnvPB9Bdsvs//7zrY3f7eLIkpIyK9cQHU+5jjJd5IT0eE=</Modulus><Exponent>AQAB</Exponent><P>83xxN7jvpg5z16pxz2tIQIdqd/EfmikR9Q2TjG2tosWkUSvtyx0xHZ9EqdTUbSGZZ+jgrabzkafYc7Mplylwew==</P><Q>yqcnYSZEXHwJvRWi2V09PNEENTozQZywcFptUUGar9TciaQvoNv3lpnfzUKNBRdhzq4lImxkamajZlTWE5buUw==</Q><DP>37HqilkbwyHwB6mOGhPkM3S1ujAK6qTk3JB2iEOTjMGrru9+7maJYz+Z47Wm3ARMXgyzrpZ9m8nqsJFfmoL11Q==</DP><DQ>v285tv8kMs2FkZYfuP/oOkwkkneBNejjj68Md2bmzlThZDCyQV2pvB1tmgPVHUsiPNCrCaKlFRISJzfa5rR8Ow==</DQ><InverseQ>fgJE2TRe/SS+YqW0/I+FtHrdfbbao0/R3pHD4r4oceZQUemlBgZ7DxOAetebHKthlOdjGkmfWYB8EU4XoWggqw==</InverseQ><D>FMLCwjy3wbAKiCANp6XFAJgz1o7365NFv0k41BpvasViTa4TgFFWH2ROJ7M9g0lPqJy+YrhrHcY9mqV5TVjTheQp0JeckrgO2B39XngPMAMMdne3rWGpf0Pfbj3FLfchMk6XYDXSZzCS2CmSeRA4aBMb+4R3YurixyJLrnGRMH0=</D></RSAKeyValue>");
        RSACryptoServiceProvider publicKey = new RSACryptoServiceProvider();
        publicKey.FromXmlString("<RSAKeyValue><Modulus>wL8s+C8SnnlaaqR+VsyijmxOJOARNa4o7ZNsqfy3+9J9Ol2JNSjjMfQWoUnFtClzJBlZhU5KtuazQe8ZKXTX9YvKoJdRhlsonZkC04qiTMdO/FZIH00GrCRxeQ7XDnQnvPB9Bdsvs//7zrY3f7eLIkpIyK9cQHU+5jjJd5IT0eE=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>");

        {
            string text = "foo";
            byte[] encrypted = publicKey.Encrypt(Encoding.UTF8.GetBytes(text), false);
            byte[] decryptedBytes = privateKey.Decrypt(encrypted, false);
        }

Você consegue double-check que a chave privada exportada é de cert.PrivateKey ea chave pública é de cert.PublicKey.Key?

me deparei com esta página quando eu estava tentando encontrar exemplos de uso makcert com x509 certificados e RSA usando c #, e, infelizmente, só forneceu uma parte da solução. Eu coloquei todos os bits juntos em uma entrada de blog que as pessoas possam estar interessados ??em, e pode ser encontrada aqui: http://nick-howard.blogspot.com /2011/05/makecert-x509-certificates-and-rsa.html

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top