Rumah >hujung hadapan web >Soal Jawab bahagian hadapan >nodejs melaksanakan penyulitan dan penyahsulitan 3des
Node.js ialah persekitaran masa jalan JavaScript berdasarkan enjin Chrome V8, yang sesuai untuk membina aplikasi web berprestasi tinggi. 3DES (Triple Data Encryption Standard) ialah algoritma penyulitan simetri yang biasa digunakan yang digunakan secara meluas dalam penghantaran dan penyimpanan data. Dalam artikel ini, kami akan memperkenalkan cara untuk melaksanakan penyulitan dan penyahsulitan 3DES menggunakan Node.js.
Mula-mula, kita perlu memasang modul Node.js bernama crypto secara setempat. Modul kripto ialah salah satu modul teras Node.js dan menyediakan banyak fungsi berkaitan keselamatan, termasuk penyulitan, penyahsulitan, pencincangan, dsb.
Anda boleh memasang modul kripto menggunakan arahan berikut:
npm install crypto
Sebelum melaksanakan penyulitan dan penyahsulitan, kita perlu menjana kunci pertama. Algoritma 3DES menggunakan panjang kunci 24 bait (192 bit). Kekunci rawak boleh dijana menggunakan kaedah randomBytes() dalam modul crypto.
Berikut ialah contoh kod untuk menjana kunci rawak:
const crypto = require('crypto'); const key = crypto.randomBytes(24); console.log(key.toString('hex'));
Menjalankan kod di atas boleh mengeluarkan rentetan rawak yang terdiri daripada 48 nombor perenambelasan, yang merupakan kunci 3DES .
Gunakan kunci yang dijana dan modul kripto untuk menyulitkan data. Algoritma penyulitan 3DES disediakan dalam modul kripto Kaedah penggunaan adalah seperti berikut:
const crypto = require('crypto'); const key = crypto.randomBytes(24); const text = 'Hello, world!'; const cipher = crypto.createCipheriv('des-ede3', key, ''); let encrypted = cipher.update(text, 'utf8', 'hex'); encrypted += cipher.final('hex'); console.log(encrypted);
Dalam kod di atas, 'des-ede3' bermaksud menggunakan algoritma penyulitan 3DES, kunci ialah kunci yang dijana sebelum ini, ' ' bermaksud menggunakan vektor yang disulitkan lalai.
Akhir sekali, gunakan kaedah createCipheriv() untuk mencipta sifir objek sifir, dan gunakan kaedah kemas kini() untuk menghantar teks untuk disulitkan kepadanya 'utf8' mewakili kaedah pengekodan teks, dan 'hex' mewakili pengekodan kaedah output, dan akhirnya menggunakan kaedah final() untuk mengeluarkan hasil penyulitan.
Gunakan kunci yang dijana dan modul kripto untuk menyahsulit data dengan cara yang sama seperti menyulitkan data. Kaedah createDecipheriv() disediakan dalam modul crypto untuk mencipta objek penyahsulitan Kaedah penggunaan adalah seperti berikut:
const crypto = require('crypto'); const key = crypto.randomBytes(24); const text = 'Hello, world!'; const cipher = crypto.createCipheriv('des-ede3', key, ''); let encrypted = cipher.update(text, 'utf8', 'hex'); encrypted += cipher.final('hex'); console.log(encrypted); const decipher = crypto.createDecipheriv('des-ede3', key, ''); let decrypted = decipher.update(encrypted, 'hex', 'utf8'); decrypted += decipher.final('utf8'); console.log(decrypted);
Dalam kod di atas, gunakan kaedah createDecipheriv() untuk mencipta penyahsulit objek penyahsulitan, dan gunakan kaedah kemas kini() Hantarkan teks untuk dinyahsulit, 'hex' mewakili kaedah pengekodan hasil input, 'utf8' mewakili kaedah pengekodan hasil output, dan akhirnya gunakan kaedah akhir() untuk mengeluarkan hasil dekripsi hasil.
Dengan cara ini, kami menggunakan Node.js untuk melaksanakan penyulitan dan penyahsulitan 3DES. Jika keselamatan yang lebih maju diperlukan, algoritma penyulitan lain yang lebih berkuasa boleh digunakan, seperti AES (Advanced Encryption Standard), dsb.
Ringkasan
Artikel ini memperkenalkan cara menggunakan Node.js untuk melaksanakan penyulitan dan penyahsulitan 3DES, meliputi operasi asas seperti menjana kunci, menyulitkan data dan menyahsulit data. Modul kripto Node.js menyediakan pelbagai fungsi berkaitan keselamatan, yang boleh melaksanakan pelbagai operasi penyulitan dan penyahsulitan dengan mudah.
Atas ialah kandungan terperinci nodejs melaksanakan penyulitan dan penyahsulitan 3des. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!