
	                	                 
openssl_dh_compute_key 함수는 두 개의 공개 키를 입력받아 공유 키를 계산하는 역할을 합니다. 이 함수가 반환하는 공유 키의 형식은 DER(ASN.1 DER) 형식입니다. 
공유 키를 사용하려면, 먼저 공유 키를 DER 형식으로 디코딩해야 합니다. DER 형식은 바이너리 데이터이기 때문에, 일반적으로 DER 형식으로 디코딩한 후, 그 값을 문자열로 변환하여 사용하거나, 바이너리 데이터로 사용할 수 있습니다. 
openssl_dh_compute_key 함수의 사용법은 다음과 같습니다.
1. 두 개의 공개 키를 입력받아 공유 키를 계산합니다.
2. 계산된 공유 키를 DER 형식으로 디코딩합니다.
3. 디코딩된 공유 키를 필요에 따라 사용합니다.
예를 들어, 다음 코드는 openssl_dh_compute_key 함수를 사용하여 공유 키를 계산하고, 그 값을 DER 형식으로 디코딩한 후, 문자열로 변환하여 출력합니다.
#hostingforum.kr
c
#include 
#include 
#include 
#include 
int main() {
    // DH 구조체를 생성합니다.
    DH *dh = DH_new();
    if (dh == NULL) {
        ERR_print_errors_fp(stderr);
        return 1;
    }
    // DH 구조체에 공개 키를 설정합니다.
    if (DH_set_length(dh, 2048) != 1) {
        ERR_print_errors_fp(stderr);
        return 1;
    }
    // 두 개의 공개 키를 입력받아 공유 키를 계산합니다.
    unsigned char *shared_key = (unsigned char *)malloc(dh->p->length);
    if (dh->p->length != 0) {
        if (openssl_dh_compute_key(shared_key, dh->p, dh->g, dh) != 1) {
            ERR_print_errors_fp(stderr);
            return 1;
        }
    }
    // 계산된 공유 키를 DER 형식으로 디코딩합니다.
    unsigned char *der_key = (unsigned char *)malloc(dh->p->length);
    if (i2d_DHparams(dh, &der_key) != 1) {
        ERR_print_errors_fp(stderr);
        return 1;
    }
    // 디코딩된 공유 키를 문자열로 변환합니다.
    char *hex_key = (char *)malloc(2 * dh->p->length + 1);
    if (BN_bn2hex(BN_bin2BN(dh->p, der_key), hex_key) != 1) {
        ERR_print_errors_fp(stderr);
        return 1;
    }
    // 문자열로 변환된 공유 키를 출력합니다.
    printf("%sn", hex_key);
    // 메모리를 해제합니다.
    free(shared_key);
    free(der_key);
    free(hex_key);
    DH_free(dh);
    return 0;
}
이 코드는 openssl_dh_compute_key 함수를 사용하여 공유 키를 계산하고, 그 값을 DER 형식으로 디코딩한 후, 문자열로 변환하여 출력합니다.
2025-07-18 18:24