使用OpenSSL Qt,C ++解密DES

时间:2013-12-19 17:44:59

标签: c++ qt encryption openssl des

我正在使用Qt库在C ++中编写一个新版本的程序,并希望保持与用C#编写的旧版本的兼容性。

如何将此代码转换为C ++ / Qt?

DESCryptoServiceProvider dESCryptoServiceProvider = new DESCryptoServiceProvider();
emoryStream stream = new  MemoryStream(Convert.FromBase64String(p0));
CryptoStream stream2 = new CryptoStream(stream,     dESCryptoServiceProvider.CreateDecryptor(Encoding.ASCII.GetBytes("B5B126C5"), 
Encoding.UTF32.GetBytes("0907427F93EC3A3FCFDFEBE3CB55011")), CryptoStreamMode.Read);
StreamReader streamReader = new StreamReader(stream2);
String text = streamReader.ReadToEnd();

我的Qt / C ++代码:

        QByteArray encrypted = code.toLatin1();
        encrypted = QByteArray::fromBase64(encrypted);

     /////////////////////////////////////////////////////////////////////////////////////
        DES_cblock key = { 0x9, 0x7, 0x42, 0x7, 0xf9, 0x3e, 0xC3, 0xa3, 0xfC, 0xfd, 0xfe, 0xbe, 0x3c, 0xb5, 0x50, 0x85 };
                    //this key is too long...

    ///////////////////////////////////////////////////////////////////////////////////////
        DES_cblock iv = { 0xB5, 0xb1, 0x26, 0xc11 };

        DES_key_schedule schedule;
        unsigned char decrypted[encrypted.size()];

        DES_set_odd_parity(&key);
        DES_set_key_checked(&key, &schedule);
        DES_ncbc_encrypt((unsigned char * )encrypted.constData(), (unsigned char * )decrypted, encrypted.size(), &schedule, &iv, DES_DECRYPT);
        unsigned int data_size = 0;

        QString text = QByteArray::fromRawData((char * )decrypted, data_size);

当我尝试构建时收到错误:

C:\Project1_Qt\trunk\Core\OldHashDecoder.cpp:1383: error: too many initializers for 'DES_cblock {aka unsigned char [8]}'

请帮忙 最好的问候

1 个答案:

答案 0 :(得分:1)

这里有几个问题正在进行中。

  • 您在评论中注意到自己有一个很长的密钥。你需要缩短它。

  • DES密钥具有固定长度,正如评论中所述。

  • 您无法在一个字节中修复0xc11。

至于C#代码,你粘贴了,我不确定。我不擅长那种语言,但也许它可能会默默地缩短你的长度。