4

我使用 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, 0, 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);
}
4

2 回答 2

1

memset(decrypt, 0, encrypt_len);我通过在“ ”之后使用“”初始化解密来解决问题decrypt = malloc(encrypt_len);。谢谢大家。

于 2013-08-01T00:17:04.380 回答
0

问题是您应该使用解密后的大小,而不是直接将解密的输出视为空终止字符串。

RSA_private_decrypt()返回恢复的明文的大小。

于 2013-07-31T21:05:04.090 回答