
sodium_crypto_pwhash_scryptsalsa208sha256_str 함수는 salt 값의 길이를 32바이트로 제한합니다.
이 함수는 salt 값의 길이가 32바이트를 넘을 경우 오류를 발생시키는 것입니다.
이러한 오류를 해결하기 위해서는 salt 값의 길이를 32바이트 이하로 제한하거나, 다른 함수를 사용하는 방법이 있습니다.
salt 값의 길이를 제한하는 방법은 다음과 같습니다.
1. salt 값의 길이를 32바이트 이하로 제한하여 함수를 호출합니다.
2. 다른 함수를 사용하여 salt 값을 생성합니다. 예를 들어, sodium_randombytes_buf 함수를 사용하여 32바이트의 난수 값을 생성할 수 있습니다.
다음은 예제입니다.
#hostingforum.kr
c
#include
int main() {
unsigned char salt[32];
unsigned char hash[64];
// 32바이트의 난수 값을 생성합니다.
sodium_randombytes_buf(salt, 32);
// salt 값을 사용하여 비밀번호 해시를 생성합니다.
if (sodium_crypto_pwhash_scryptsalsa208sha256_str(hash, 64, "비밀번호", strlen("비밀번호"), salt, 32, 4096, 8, 1) != 0) {
printf("오류가 발생했습니다.n");
return 1;
}
// 비밀번호 해시를 출력합니다.
printf("비밀번호 해시: ");
for (int i = 0; i < 64; i++) {
printf("%02x", hash[i]);
}
printf("n");
return 0;
}
이 예제는 32바이트의 난수 값을 생성하여 salt 값을 사용하여 비밀번호 해시를 생성합니다.
2025-06-06 06:20