개발자 Q&A

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

2025.06.14 16:25

sodium_crypto_sign_detached 함수 사용 시 에러 발생

목록
  • 깃허브매니아 오래 전 2025.06.14 16:25
  • 66
    1
저는 현재 Ed25519 형식의 비밀키를 사용해 detached signature를 생성하려고 합니다.
sodium_crypto_sign_detached 함수를 사용했지만, 에러가 발생하고 있습니다.
함수 사용 시 에러가 발생하는 이유를 알고 싶습니다.
해결 방법을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    sodium_crypto_sign_detached 함수는 detached signature를 생성하기 위해 사용됩니다. 이 함수는 Ed25519 형식의 비밀키와 메시지의 해시를 입력으로 받아 detached signature를 반환합니다.

    에러가 발생하는 이유는 여러 가지가 있을 수 있습니다.

    1. 비밀키가 유효하지 않은 경우: 비밀키가 유효하지 않거나 Ed25519 형식이 아닌 경우 에러가 발생할 수 있습니다.
    2. 메시지의 해시가 유효하지 않은 경우: 메시지의 해시가 유효하지 않거나 64바이트가 아닌 경우 에러가 발생할 수 있습니다.
    3. 함수를 사용하는 환경이 부적절한 경우: 함수를 사용하는 환경이 부적절한 경우 에러가 발생할 수 있습니다.

    해결 방법은 다음과 같습니다.

    1. 비밀키를 확인합니다. 비밀키가 유효한지 확인하고 Ed25519 형식인지 확인합니다.
    2. 메시지의 해시를 확인합니다. 메시지의 해시가 유효한지 확인하고 64바이트인지 확인합니다.
    3. 함수를 사용하는 환경을 확인합니다. 함수를 사용하는 환경이 부적절한지 확인합니다.

    예를 들어, 다음 코드는 sodium_crypto_sign_detached 함수를 사용하는 방법을 보여줍니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        unsigned char secret_key[32];
    
        unsigned char message_hash[64];
    
        unsigned char signature[64];
    
    
    
        // 비밀키를 생성합니다.
    
        sodium_init();
    
        randombytes_secretkey(secret_key, 32);
    
    
    
        // 메시지의 해시를 생성합니다.
    
        unsigned char message[] = "Hello, World!";
    
        crypto_hash_sha256(message_hash, message, strlen((char*)message));
    
    
    
        // detached signature를 생성합니다.
    
        if (sodium_crypto_sign_detached(signature, message_hash, secret_key) != 0) {
    
            printf("Error: %sn", sodium_strerror(sodium_errno()));
    
            return 1;
    
        }
    
    
    
        printf("Detached signature: ");
    
        for (int i = 0; i < 64; i++) {
    
            printf("%02x", signature[i]);
    
        }
    
        printf("n");
    
    
    
        return 0;
    
    }
    
    


    이 코드는 sodium_crypto_sign_detached 함수를 사용하여 detached signature를 생성합니다. 비밀키와 메시지의 해시를 입력으로 받아 detached signature를 반환합니다.

    2025-06-14 16:26

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

검색

게시물 검색