I am decrypting some java-crypted text with OpenSSL. Reading this post I wrote the following code.
unsigned int i = 0; printf("Out array - Before\n"); for(i = 0; i < sizeof(out); i++) { if(i % 32 == 0) printf("\n"); printf("%02X", out[i]); } printf("\n"); AES_set_decrypt_key((const unsigned char *)a.at(3).c_str(), 128, &aesKey_); for(i = 0; i < sizeof(bytes); i += AES_BLOCK_SIZE) { std::cout << "Decrypting at " << i << " of " << sizeof(bytes) << "\n"; AES_ecb_encrypt(bytes + i, out + i, &aesKey_, AES_DECRYPT); } std::cout << "HEX : " << a.at(2).c_str() << "\n" << "Decrypting : " << bytes << "\n" << "With Key : " << a.at(3).c_str() << "\n" << "Becomes : " << out << "\n"; printf("Out array - AFTER\n"); for(i = 0; i < sizeof(out); i++) { if(i % 32 == 0) printf("\n"); printf("%02X", out[i]); } printf("\n");
The decryption of the data seems to be fine, although PKCS5-padding
gets decryption along and some extra garbage (I assume this is due to PKCS5-padding
).
Out array - BEFORE 0000000000000000000000000000000000000000000000000000000000000000 Decrypting at 0 of 18 Decrypting at 16 of 18 HEX : B00FE0383F2E3CBB95A5A28FA91923FA00 Decrypting : 8?.<
The above is deduced from my code, no passwordHQ
( 6E6F2070617373776F72644851
) is the expected output, but you can see that the filling is decoded 030303
, followed by the garbage C7457F5ACCF12DAA053D252E3708846E
.
So, how do I install the add-on in OpenSSL?
I expected that there would be an AES_set_padding
function (or similar), but I obviously missed it in the documentation.
source share