개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.16 07:31

openssl_dh_compute_key에 대한 질문입니다.

목록
  • 웹퍼포먼스광 5일 전 2025.04.16 07:31
  • 81
    1
openssl_dh_compute_key 함수에 대한 질문입니다.

openssl_dh_compute_key 함수에 대해 이해를 못하고 있습니다. 이 함수는 public key와 private key를 이용하여 공통 키를 생성하는 것 같습니다. 하지만 저는 public key와 private key를 어떻게 사용해야 하는지, 그리고 이 함수가 반환하는 값이 정확히 무엇인지 이해를 못하고 있습니다.

public key와 private key를 어떻게 사용해야 하는지 알려주세요. 또한, 이 함수가 반환하는 값은 정확히 무엇인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  5일 전



    openssl_dh_compute_key 함수는 Diffie-Hellman 키 교환 알고리즘을 사용하여 공통 키를 생성하는 함수입니다. 이 함수는 두 개의 매개 변수를 받는데, 하나는 공유된 Diffie-Hellman 공개 키(p)이고, 다른 하나는 사용자의 개인 키(private key)입니다.

    공개 키(p)는 Diffie-Hellman 키 교환 알고리즘의 공유된 공개 키로, 이 키는 두 개의 참여자 간에 공유됩니다. 개인 키(private key)는 사용자의 개인 키로, 이 키는 사용자가 알고 있어야 합니다.

    이 함수는 사용자의 개인 키(private key)를 입력으로 받고, 공통 키를 반환합니다. 반환된 공통 키는 두 개의 참여자 간에 공유된 키로, 이 키는 사용자가 알고 있어야 합니다.

    openssl_dh_compute_key 함수의 예제는 다음과 같습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        // Diffie-Hellman 키 교환 알고리즘을 초기화합니다.
    
        DH *dh = DH_new();
    
        if (!dh) {
    
            return -1;
    
        }
    
    
    
        // 공유된 Diffie-Hellman 공개 키(p)를 생성합니다.
    
        BIGNUM *p = BN_new();
    
        BN_set_word(p, 23);
    
        DH_set0_pqg(dh, NULL, p, NULL);
    
    
    
        // 사용자의 개인 키(private key)를 생성합니다.
    
        BIGNUM *priv_key = BN_new();
    
        BN_set_word(priv_key, 5);
    
        DH_set0_key(dh, priv_key, NULL);
    
    
    
        // 공통 키를 생성합니다.
    
        unsigned char *shared_key = (unsigned char *)malloc(DH_size(dh));
    
        if (!shared_key) {
    
            return -1;
    
        }
    
        if (DH_compute_key(shared_key, dh->pub_key, dh->priv_key) != 1) {
    
            return -1;
    
        }
    
    
    
        // 공통 키를 사용합니다.
    
        printf("공통 키: ");
    
        for (int i = 0; i < DH_size(dh); i++) {
    
            printf("%02x", shared_key[i]);
    
        }
    
        printf("n");
    
    
    
        // 메모리를 해제합니다.
    
        free(shared_key);
    
        BN_free(p);
    
        BN_free(priv_key);
    
        DH_free(dh);
    
    
    
        return 0;
    
    }
    
    


    이 예제에서는 Diffie-Hellman 키 교환 알고리즘을 사용하여 공통 키를 생성합니다. 사용자의 개인 키(private key)는 `5`로 설정되어 있습니다. 반환된 공통 키는 `public_key`와 `private_key`를 사용하여 생성된 키입니다.

    2025-04-16 07:32

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 13,162건 / 56 페이지

검색

게시물 검색