加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用c#加密数据并使用openssl api对其进行解密,为什么解密数据末

发布时间:2020-12-15 21:54:10 所属栏目:百科 来源:网络整理
导读:我使用RSA(1024)来加密/解密字符串.加密是使用公钥实现的,用C#编写,解密由c实现.我加密字符串: 86afaecb-c211-4d55-8e90-2b715d6d64b9 并将加密数据写入文件.然后,我使用openssl api从文件中读取加密数据并解密.但是,我得到的输出为: 86afaecb-c211-4d55-8
我使用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: %sn",decrypt);
}

解决方法

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读