データを保護したいので、XXTEA で暗号化してみます。私はこのようにします:
- 入力文字列 -> XXTEA 暗号化 -> 出力文字列
- outputString -> XXTEA 復号化 -> inputString
すべてが暗号化と復号化に問題ありません。しかし、XXTEA で暗号化した後に出力を base64 エンコードし、XXTEA で復号化する前に base64 でデコードしようとすると、結果が間違っています。
- 入力 -> XXTEA 暗号化 -> base64 エンコード -> 出力
- 出力 -> base64 デコード -> XXTEA 復号化 != 入力
http://www.tools4noobs.com/online_tools/xxtea_encrypt/とhttp://www.tools4noobs.com/online_tools/xxtea_decrypt/でテストすると
私の例の入力文字列はhello
、その最終結果はbjz/S2f3Xkxr08hu
しかし、コードでテストすると (以下を参照)、最終結果は次のようになります。bjz/Sw==
これが私のものencryption code
です:
std::string ProjectUtils::encrypt_data_xxtea(std::string input, std::string secret) {
//Encrypt with XXTEA
xxtea_long retLength = 0;
unsigned char data[input.length()];
strncpy((char*)data, input.c_str(), sizeof(data));
xxtea_long dataLength = (xxtea_long) sizeof(data);
unsigned char key[secret.length()];
strncpy((char*)key, secret.c_str(), sizeof(key));
xxtea_long keyLength = (xxtea_long) sizeof(key);
unsigned char *encryptedData = xxtea_encrypt(data, dataLength, key, keyLength, &retLength);
//Encode base64
char* out = NULL;
base64Encode(encryptedData, sizeof(encryptedData), &out);
CCLOG("xxtea encrypted data: %s", out);
return out;
}
これが私のものdecryption code
です:
char* ProjectUtils::decrypt_data_xxtea(std::string input, std::string secret) {
//Decode base64
unsigned char* output = NULL;
base64Decode((unsigned char*)input.c_str(), (unsigned int)strlen(input.c_str()), &output);
xxtea_long dataLength = (xxtea_long) sizeof(output);
xxtea_long retLength = 0;
unsigned char key[secret.length()];
strncpy((char*)key, secret.c_str(), sizeof(key));
xxtea_long keyLength = (xxtea_long) sizeof(key);
//Decrypt with XXTEA
char *decryptedData = reinterpret_cast<char*>(xxtea_decrypt(output, dataLength, key, keyLength, &retLength));
CCLOG("xxtea decrypted data: %s", decryptedData);
return decryptedData;
}
私のコードの何が問題なのか知っていますか? どんな助けでも大歓迎です!どうもありがとう。