crypto.scrypt() วิธีการจัดเตรียมการใช้งานแบบอะซิงโครนัสสำหรับวิธีการเข้ารหัส การเข้ารหัสสามารถกำหนดเป็นฟังก์ชันการได้มาของคีย์ที่ใช้รหัสผ่านซึ่งปกป้องระบบจากการโจมตีแบบเดรัจฉานและทำให้ไม่มีเป้าหมาย แต่ฟังก์ชันสคริปต์นั้นมีราคาแพงทั้งในด้านการคำนวณและด้านหน่วยความจำ
ไวยากรณ์
crypto.scrypt(password, salt, keylen, [options], [callback])
พารามิเตอร์
พารามิเตอร์ข้างต้นอธิบายไว้ด้านล่าง −
-
รหัสผ่าน – ฟิลด์รหัสผ่านสำหรับ scrypt ที่จำเป็นในการถอดรหัสรายการ อาจเป็นสตริง วัตถุ TypedArray เป็นต้น
-
เกลือ – ค่านี้ควรไม่ซ้ำกันมากที่สุด ส่วนใหญ่จะใช้สำหรับการเข้ารหัสข้อมูล ความยาวเกลือขั้นต่ำที่แนะนำคือ 16 ไบต์
-
คีเลน – พารามิเตอร์นี้กำหนดความยาวของคีย์และควรเป็นตัวเลข
-
ตัวเลือก
-
ค่าใช้จ่าย – นี่คือค่าใช้จ่ายของ cpu สำหรับแต่ละหน่วยความจำที่ใช้ ค่านี้ควรเป็นยกกำลัง 2 มากกว่า 1 ค่าเริ่มต้นคือ 16384
-
ขนาดบล็อก – พารามิเตอร์นี้กำหนดค่าสำหรับแต่ละขนาดบล็อก ค่าเริ่มต้นคือ 8
-
การทำให้ขนานกัน – พารามิเตอร์นี้กำหนดพารามิเตอร์การทำให้ขนานกัน ค่าเริ่มต้นคือ 1
-
ไม่มี – พารามิเตอร์นี้เป็นนามแฝงสำหรับต้นทุนและสามารถใช้แทนได้ สามารถกำหนดได้ครั้งละหนึ่งรายการเท่านั้น
-
ร – พารามิเตอร์นี้เป็นนามแฝงสำหรับ blockSize และในทำนองเดียวกันสามารถกำหนดได้ครั้งละหนึ่งรายการเท่านั้น
-
p – นามแฝงสำหรับการขนาน กำหนดได้เพียงอันเดียวเท่านั้น
-
maxmem – นี่คือค่าขอบเขตบนของหน่วยความจำ เกิดข้อผิดพลาดเมื่อ 128*N*r> maxmem ค่าเริ่มต้นคือ 32*1024*1024
-
-
โทรกลับ – ฟังก์ชันนี้จะถูกเรียกเมื่อมีข้อผิดพลาดเกิดขึ้นหากคุณต้องการจัดการ
ตัวอย่าง
สร้างไฟล์ที่มีชื่อ – scrypt.js และคัดลอกข้อมูลโค้ดด้านล่าง หลังจากสร้างไฟล์แล้ว ให้ใช้คำสั่งต่อไปนี้เพื่อเรียกใช้โค้ดนี้ดังแสดงในตัวอย่างด้านล่าง −
node scrypt.js
scrypt.js
// Node.js program to demonstrate the flow of crypto.scrypt() method // Importing the crypto module var crypto = require('crypto'); // Calling the scrypt() method with the below parameters crypto.scrypt('tutorialspoint', 'asdfghjkl', 32, (err, derivedKey) => { if (err) throw err; // Prints the derived key as a buffer value console.log("The derived key(1) is:", derivedKey); }); // Calling the scrypt() method with the cost option crypto.scrypt('GeeksforGeeks', 'tfytdx', 128, { N: 512 }, (err, derivedKey) => { if (err) throw err; // Prints the derived key as a buffer value console.log("The derived key(2) is:", derivedKey); console.log(); });
ผลลัพธ์
C:\home\node>> node scrypt.js The derived key(2) is: <Buffer b3 f8 72 5f 58 df 98 d9 c0 8a ba 0c 2c 50 85 b1 76 de 39 35 40 27 7d 57 f1 6a a1 07 54 dc c9 63 65 32 f2 db 29 95 dc ee 0b 9f e3 d5 0a 9e 3a d0 f6 b4 ... > The derived key(1) is: <Buffer ae 50 38 61 17 f7 11 51 e4 50 63 3c 2a 9c ec f0 46 42 a6 ca 04 78 67 05 c8 8c 0c 69 00 c3 03 7f>
ตัวอย่าง
ลองดูอีกตัวอย่างหนึ่ง
// Node.js program to demonstrate the flow of crypto.scrypt() method // Importing the crypto module var crypto = require('crypto'); // Initializing the value of salt as a typedArray const salt = new Uint32Array(7); // Using the scrypt() method with below parameters crypto.scrypt('WelcomeTutorialspoint', salt, 16, (err, derivedKey) => { if (err) throw err; // Printing the derived key in encoded string format console.log("The derived key(1) is:", derivedKey.toString("ascii")); }); // Initialising the value of salt as a DataView const newSalt = new DataView(new ArrayBuffer(5)); // Using the script() method with cost parameter crypto.scrypt('HelloTutorialspoint', newSalt, 16, { N: 32 }, (err, derivedKey) => { if (err) throw err; // Printing the derived key in encoded string format console.log("The derived key(2) is:", derivedKey.toString("base64")); });
ผลลัพธ์
C:\home\node>> node scrypt.js The derived key(2) is: PBYDRlgayLVGjC8z3YUcSQ== The derived key(1) is: <Uu0allCb,d?,Z5_