2

我想制作加密(稍后解密)用户输入字符串的程序。这是加密的开始:

QString getData = ui->text->toPlainText(); //Data to process
std::string output; //Result will be Base32 encoded string, so std::string is fine.

现在,我必须转换QStringchar*std::string以便它可以被 Crypto++ 接受。我认为这QByteArray很好,因为它具有.data()返回char *. (getData总是 17 个或更多字节长:CryptoPP 需要至少 17 个字节用于 AES 加密)。所以,我使用了以下代码:

QByteArray data;
data.append(getData);

//Creating key and iv:

//Creating AES encryptor:

//Encrypting AES and Base32:
CryptoPP::StringSource ss((const byte*)data.data(), data.size() , true,
    new CryptoPP::StreamTransformationFilter( Encryptor,
        new CryptoPP::Base32Encoder(
                new CryptoPP::StringSink(output)
        ) // Base32Encoder
    ) // StreamTransformationFilter
); // StringSource

ui->text->clear();
getData = output.c_str();
ui->text->setText(getData);

一切似乎都很好。但我希望它支持非 ASCII 字符(我的意思是俄语、立陶宛语等)。解密后变为?. 我该如何解决这个问题?我明白,这不std::string支持他们。


编辑:这是更新的代码:

加密:

QString getData = ui->text->toPlainText(); //Data to process
std::string output;

QByteArray data = getData.toUtf8();

//Creating key and iv: <..>

//Creating AES encryptor: <..>

//Encrypting AES and Base32:
CryptoPP::StringSource ss((const byte*) data.data(),getData.size()*2, true,
    new CryptoPP::StreamTransformationFilter( Encryptor,
        new CryptoPP::Base32Encoder(
                new CryptoPP::StringSink(output)
        ) // Base32Encoder
    ) // StreamTransformationFilter
); // StringSource

ui->text->clear();
getData = output.c_str();
ui->text->setText(getData);

和解密:

QString getData = ui->text->toPlainText();
QByteArray data;
data.append(getData);
std::string output;

//Creating key and iv:
byte key[ CryptoPP::AES::DEFAULT_KEYLENGTH ],
      iv[ CryptoPP::AES::BLOCKSIZE ];

//Memsetting them: (randomization needed)
::memset( key, 0x01, CryptoPP::AES::DEFAULT_KEYLENGTH );
::memset(  iv, 0x01, CryptoPP::AES::BLOCKSIZE );

//Creating AES decryptor:
CryptoPP::CBC_Mode<CryptoPP::AES>::Decryption decryptor( key, sizeof(key), iv );

//Decrypting Base32 and AES
CryptoPP::StringSource ss((const byte*) data.data(), data.size(), true,
    new CryptoPP::Base32Decoder(
        new CryptoPP::StreamTransformationFilter( Decryptor,
            new CryptoPP::StringSink(output)
        ) // StreamTransformationFilter
    ) // Base32Encoder
); // StringSource

ui->text->clear();
getData = QString::fromUtf8(output.c_str());
ui->text->setText(getData);

它有我错过的任何错误吗?

4

2 回答 2

1

我认为从 QString 转换为 QByteArray 时会丢失数据。试试这个:

QByteArray data = getData.toUtf8();

...

getData = QString::fromUtf8( output.c_str() );
于 2010-08-03T16:31:05.423 回答
0

改为使用reinterpret_cast<byte*>(QString::data())。不要尝试在这里实际进行代码页转换——AES 不在乎。使用ArraySink而不是 StringSink。

请记住,实际 QString::data() 缓冲区的大小是其中包含的字符数的两倍,因为它使用 UTF-16。

于 2010-08-03T16:23:52.970 回答