개발자 Q&A

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

2025.07.19 07:28

sodium_crypto_scalarmult 함수 이해에 도움이 필요합니다

목록
  • 리버스엔지니어링도령 2일 전 2025.07.19 07:28
  • 11
    1
저는 sodium_crypto_scalarmult 함수를 사용하여 Curve25519 키 쌍을 생성한 후, 이 키 쌍을 사용하여 암호화를 하려고 합니다.
하지만, curve25519_private_key를 curve25519_public_key로 변환하는 과정에서 어려움을 겪고 있습니다.
sodium_crypto_scalarmult 함수의 curve25519_private_key와 curve25519_public_key를 어떻게 사용해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  2일 전



    sodium_crypto_scalarmult 함수는 Elliptic Curve Diffie-Hellman (ECDH) 키 교환을 위한 함수입니다. 이 함수는 private key와 public key를 받아서 shared secret을 생성합니다.

    curve25519_private_key는 개인 키를 의미하고, curve25519_public_key는 공개 키를 의미합니다.

    sodium_crypto_scalarmult 함수를 사용하려면, 다음 단계를 따르세요:

    1. curve25519_private_key를 curve25519_public_key로 변환하는 것은 불가능합니다. curve25519_private_key는 개인 키로 사용되며, curve25519_public_key는 공개 키로 사용됩니다.
    2. curve25519_private_key와 curve25519_public_key를 사용하여 sodium_crypto_scalarmult 함수를 호출하세요. 이 함수는 private key와 public key를 받아서 shared secret을 생성합니다.
    3. 생성된 shared secret을 사용하여 암호화를 하세요.

    예제를 살펴보겠습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    // curve25519_private_key와 curve25519_public_key를 생성합니다.
    
    unsigned char private_key[32];
    
    unsigned char public_key[32];
    
    sodium_init();
    
    sodium_crypto_sign_keypair(public_key, private_key);
    
    
    
    // curve25519_private_key와 curve25519_public_key를 사용하여 shared secret을 생성합니다.
    
    unsigned char shared_secret[32];
    
    sodium_crypto_scalarmult(shared_secret, private_key, public_key);
    
    
    
    // 생성된 shared secret을 사용하여 암호화를 하세요.
    
    


    이 예제에서는 sodium_crypto_scalarmult 함수를 사용하여 curve25519_private_key와 curve25519_public_key를 사용하여 shared secret을 생성한 후, 생성된 shared secret을 사용하여 암호화를 하세요.

    2025-07-19 07:29

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

검색

게시물 검색