Computer >> 컴퓨터 >  >> 프로그램 작성 >> JavaScript

Node.js의 crypto.pbkdf2() 메서드

<시간/>

암호 기반 키 파생 함수라고도 하는 crypto.pbkdf2()는 파생 함수의 비동기 구현을 제공합니다. 키는 암호, 솔트 및 반복에서 지정된 알고리즘의 Hmac 다이제스트를 사용하여 파생됩니다.

구문

crypto.createHmac(알고리즘, 키, [옵션])

매개변수

위의 매개변수는 다음과 같이 설명됩니다 -

  • 비밀번호 – 요청된 바이트 길이의 키를 가져오기 위해 정의된 암호입니다. 가능한 값은 문자열, DataView, Buffer 등입니다.

  • 소금 – 키를 얻기 위한 비밀번호와 유사합니다. 가능한 값은 문자열, DataView, Buffer 등입니다.

  • 반복 – 요청된 바이트 길이의 원하는 키 가져오기. 값을 숫자로 받아들입니다.

  • 키렌 – 키의 요청된 바이트 길이입니다. 유형 번호입니다.

  • 다이제스트 – Hmac 알고리즘은 이 다이제스트 값으로 지정됩니다. 기본값은 'sha1'입니다.

  • 콜백 – 비동기 모드에서 오류가 발생하면 콜백에서 처리됩니다.

예시

이름이 pbkdf2.js인 파일을 만들고 아래 코드 조각을 복사합니다. 파일을 생성한 후 다음 명령을 사용하여 아래 예와 같이 이 코드를 실행하십시오 -

노드 pbkdf2.js

pbkdf2.js

// crypto.pbkdf2() 데모 예제// 암호화 모듈 가져오기 const crypto =require('crypto');// 다음 옵션으로 pbkdf2 정의crypto.pbkdf2('secret', 'salt', 100000, 64 , 'sha512', (err, 파생키) => { if (err) throw err; // 파생 키 출력 console.log("Key Derived:",derivedKey.toString('hex'));}); 

출력

C:\home\node>> 노드 pbkdf2.jsKey 파생:3745e482c6e0ade35da10139e797157f4a5da669dad7d5da88ef87e47471cc47ed941c7ad618e82730

예시

예를 하나 더 살펴보겠습니다.

// crypto.pbkdf2() 데모 예제// 암호화 모듈 가져오기const crypto =require('crypto');// 다음 옵션으로 pbkdf2 정의crypto.pbkdf2('secret', 'salt', 100, 64 , 'sha1', (err, 파생키) => { if (err) throw err; // 파생 키 출력 console.log("Key Derived:",derivedKey); console.log("Key Derived in hex:" ,derivedKey.toString('hex')); console.log("base64에서 파생된 키:",derivedKey.toString('base64'));});

출력

C:\home\node>> 노드 pbkdf2.jsKey 파생:<버퍼 b7 36 35 f7 c0 88 2e 1f c3 ba 6e 29 b1 4a f1 27 4d f8 48 28 b4 d1 8f cc 22 4 50 b5 5D 3D 23 19 13 84 2D E1 E2 91 A7 83 00 73 37 4A 24 4E B6는 ...> 키 헥스 유도 :b73635f7c0882e1fc3ba6e29b14af1274df84828b4d18fcc222eb574455f505d3d2319132d84e191a783e200734e374a24b62cfab65dfb5e9dc28ae147072419Key base64로 유도 :tzY198CILh은 / Dum4psUrxJ034SCi00Y / MIi61dEVfUF09IxkTLYThkaeD4gBzTjdKJLYs + + rZd 16dworhRwckGQ ==