我使用RSA(1024)来加密/解密字符串.加密是使用公钥实现的,用C#编写,解密由c实现.我加密字符串:
86afaecb-c211-4d55-8e90-2b715d6d64b9
并将加密数据写入文件.然后,我使用openssl api从文件中读取加密数据并解密.但是,我得到的输出为:
86afaecb-c211-4d55-8e90-2b715d6d64b9oeheBjQ8fo1AmDnor1D3BLuPyq9wJBAOV+M/WVNYzYr
PJBKoskOj+4LaNpT+SpkfK81nsnQEbHbjgao4eHNU+PmWl9
似乎原始字符串末尾有一些无用的填充.为什么会这样?以及如何解决问题?
一些代码段如下所示:
// Encrypt { string plainData = “86afaecb-c211-4d55-8e90-2b715d6d64b9”; RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); rsa.ImportParameters(paraPub); byte[] testData = Encoding.UTF8.GetBytes(plainData); byte[] encryptedData = rsa.Encrypt(testData,true); FileStream pFileStream = null; string fileName = "encryptedData.dat"; pFileStream = new FileStream(fileName,FileMode.OpenorCreate); pFileStream.Write(encryptedData,encryptedData.Length); ... } // Decrypt { char *encrypt = malloc(RSA_size(privateKey)); FILE *out = fopen("encryptedData.dat","r"); int encrypt_len = fread(encrypt,sizeof(*encrypt),RSA_size(privateKey),out); fclose(out); decrypt = malloc(encrypt_len); if(RSA_private_decrypt(encrypt_len,(unsigned char*)encrypt,(unsigned char*)decrypt,privateKey,RSA_PKCS1_OAEP_PADDING) == -1) { // error handle } printf("Decrypted message: %s\n",decrypt); }
解决方法
我通过使用“memset(decrypt,encrypt_len);”初始化解密来解决问题.在“decrypt = malloc(encrypt_len);”之后.大家好
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。