암호 기반 키 파생 함수 2라고도 하는 crypto.pbkdf2Sync()는 파생 함수의 동기 구현을 제공합니다. 키는 암호, 솔트 및 반복에서 지정된 알고리즘의 Hmac 다이제스트를 사용하여 파생됩니다. 이렇게 하면 동기화 프로세스에서 키가 생성됩니다.
구문
crypto.createHmac(알고리즘, 키, [옵션])
매개변수
위의 매개변수는 다음과 같이 설명됩니다 -
-
비밀번호 – 요청된 바이트 길이의 키를 가져오기 위해 정의된 암호입니다. 가능한 값은 문자열, DataView, Buffer 등입니다.
-
소금 – 키를 얻기 위한 비밀번호와 유사합니다. 가능한 값은 문자열, DataView, Buffer 등입니다.
-
반복 – 요청된 바이트 길이의 원하는 키 가져오기. 값을 숫자로 받아들입니다.
-
키렌 – 키의 요청된 바이트 길이입니다. 유형 번호입니다.
-
다이제스트 – Hmac 알고리즘은 이 다이제스트 값으로 지정됩니다. 기본값은 'sha1'입니다.
예시
이름이 pbkdf2Sync.js인 파일을 만들고 아래 코드 조각을 복사합니다. 파일을 생성한 후 다음 명령을 사용하여 아래 예와 같이 이 코드를 실행하십시오 -
노드 pbkdf2Sync.js
pbkdf2Sync.js
// crypto.pbkdf2() 데모 예제// 암호화 모듈 가져오기const crypto =require('crypto');// 다음 옵션으로 pbkdf2 정의const pbkdfKey =crypto.pbkdf2Sync('secret', 'salt', 100000, 64, 'sha512'); // 파생된Keyconsole.log("key is:",pbkdfKey.toString('hex'));출력
출력
C:\home\node>> 노드 pbkdf2Sync.jskey는 다음과 같습니다.예시
예를 하나 더 살펴보겠습니다.
// crypto.pbkdf2Sync() 데모 예제// 암호화 모듈 가져오기const crypto =require('crypto');// 다음 옵션으로 pbkdf2Sync 정의const pbkdfKey =crypto.pbkdf2Sync('secret', 'salt', 100, 32, 'sha1');// 파생된Keyconsole.log("key is:",pbkdfKey);console.log("key(in hex) is:",pbkdfKey.toString('hex')); console.log("key(in base64)는 ",pbkdfKey.toString('base64'));출력
C:\home\node>> 노드 pbkdf2Sync.jskey는 다음과 같습니다.키(16진수):b73635f7c0882e1fc3ba6e29b14af1274df84828b4d18fcc222eb574455f505dkey(base64):tzY198CILh/Dum4psUrxJ03