
mdecrypt_generic 함수는 OpenSSL 라이브러리를 사용하여 암호화된 데이터를 복호화하는 함수입니다. 이 함수의 인자 중 key와 iv는 암호화 알고리즘에 따라 달라집니다.
AES-256-ECB 알고리즘을 사용할 때, key의 길이는 32바이트(256비트)로 설정해야 합니다. iv는 사용하지 않습니다. 따라서 key만 설정하면 됩니다.
다음은 예제 코드입니다.
#hostingforum.kr
c
#include
// 암호화된 데이터
unsigned char encrypted_data[32];
// 복호화 키
unsigned char key[32] = {
0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,
0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24,
0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32
};
// 복호화
int decrypt(unsigned char *encrypted_data, unsigned char *decrypted_data) {
AES_KEY aes_key;
AES_set_encrypt_key(key, 256, &aes_key);
AES_decrypt(encrypted_data, decrypted_data, &aes_key);
return 0;
}
int main() {
unsigned char decrypted_data[32];
// 복호화
decrypt(encrypted_data, decrypted_data);
// 복호화 결과 확인
printf("복호화 결과: ");
for (int i = 0; i < 32; i++) {
printf("%02x ", decrypted_data[i]);
}
printf("n");
return 0;
}
복호화된 데이터가 올바르게 복호화되었는지 확인하는 방법은 복호화 결과를 검증하는 것입니다. 예를 들어, 복호화된 데이터가 원래의 데이터와 일치하는지 확인할 수 있습니다.
복호화된 데이터를 검증하는 예제 코드는 다음과 같습니다.
#hostingforum.kr
c
// 원래의 데이터
unsigned char original_data[32] = {
0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,
0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24,
0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32
};
// 복호화된 데이터
unsigned char decrypted_data[32];
// 복호화
decrypt(encrypted_data, decrypted_data);
// 복호화 결과와 원래의 데이터 비교
if (memcmp(original_data, decrypted_data, 32) == 0) {
printf("복호화 결과가 올바르다.n");
} else {
printf("복호화 결과가 올바르지 않다.n");
}
이 예제 코드에서는 복호화된 데이터와 원래의 데이터를 비교하여 복호화 결과가 올바른지 확인합니다.
2025-07-04 20:17