Rumah > hujung hadapan web > Soal Jawab bahagian hadapan > nodejs melaksanakan penyulitan dan penyahsulitan 3des

nodejs melaksanakan penyulitan dan penyahsulitan 3des

王林
Lepaskan: 2023-05-16 21:26:37
asal
1101 orang telah melayarinya

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.

  1. Pasang kebergantungan yang diperlukan

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
Salin selepas log masuk
  1. Jana kunci

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'));
Salin selepas log masuk

Menjalankan kod di atas boleh mengeluarkan rentetan rawak yang terdiri daripada 48 nombor perenambelasan, yang merupakan kunci 3DES .

  1. Sulitkan data

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);
Salin selepas log masuk

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.

  1. Nyahsulit data

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);
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan