Как зашифровать и расшифровать строку / объект в nodejs
Я хотел бы зашифровать объект, а затем расшифровать его. Шифрование работает очень хорошо, но расшифровка не удалась. Ниже мой код:
crypto_ext.js
const crypto = require("crypto")
const password = "shared_key"
const algorithm = "aes256"
export const encrypt = (text) => {
if(!text) return ''
const cipher = crypto.createCipher(algorithm, password);
let crypted = cipher.update(text, 'utf-8', 'base64');
crypted += cipher.final('base64');
return crypted;
}
export const decrypt = (text) => {
if(!text) return ''
const decipher = crypto.createDecipher(algorithm, password);
let decrypted = decipher.update(text, 'base64', 'utf-8');
decrypted += decipher.final('utf-8');
return decrypted;
}
и в моем test.js у меня есть:
import {encrypt, decrypt} from './crypto_ext.js'
let test = {key1: val1, key2: val2}
test = encrypt(JSON.stringify(test)) || test
console.log("Encrypt : ", test)
console.log("Decrypt : ", decrypt(test)) // I should have my object as string here
И вот что я получаю как ошибку:
Uncaught Error: unable to decrypt data
at unpad (decrypter.js:83)
at Decipher.webpackJsonp../node_modules/browserify-aes/decrypter.js.Decipher._final (decrypter.js:38)
at Decipher.webpackJsonp../node_modules/cipher-base/index.js.CipherBase._finalOrDigest (index.js:76)
at decrypt (crypto_ext.js:17)
...
Подскажите, пожалуйста, что я делаю не так?
3 ответа
Зависимости: crypto
пакет
Вы можете добиться кодирования и декодирования с помощью следующих кодов:-
const crypto = require('crypto');
var password = 'ojisdasjdsjabdjs';
var iv = 'kiamdksndn';
function sha1(input) {
return crypto.createHash('sha1').update(input).digest();
}
function password_derive_bytes(password, salt, iterations, len) {
var key = Buffer.from(password + salt);
for (var i = 0; i < iterations; i++) {
key = sha1(key);
}
if (key.length < len) {
var hx = password_derive_bytes(password, salt, iterations - 1, 20);
for (var counter = 1; key.length < len; ++counter) {
key = Buffer.concat([key, sha1(Buffer.concat([Buffer.from(counter.toString()), hx]))]);
}
}
return Buffer.alloc(len, key);
}
async function encode(string) {
var key = password_derive_bytes(password, '', 100, 32);
var cipher = crypto.createCipheriv('aes-256-cbc', key, Buffer.from(iv));
var part1 = cipher.update(string, 'utf8');
var part2 = cipher.final();
const encrypted = Buffer.concat([part1, part2]).toString('base64');
return encrypted;
}
async function decode(string) {
var key = password_derive_bytes(password, '', 100, 32);
var decipher = crypto.createDecipheriv('aes-256-cbc', key, Buffer.from(iv));
var decrypted = decipher.update(string, 'base64', 'utf8');
decrypted += decipher.final();
return decrypted;
}
А затем вызовите функции ниже для кодирования и декодирования
Для кодирования
await encode(JSON.stringify({'title': 'some text'}));
Для декодирования
await decode('encoded_string_to_decode');
- Метод createCipher устарел. Вместо этого используйте createCipheriv.
- Попробуй использовать
aes192
алгоритм.
Зачем заново изобретать колесо? Есть множество модулей, чтобы помочь. Kruptein легко обрабатывает все размеры и режимы клавиш AES.
const kruptein = require('kruptein');
kruptein.init({secret: 'squirrel'});
let ciphertext = kruptein.set('Some kind of secret');
let plaintext = kruptein.get(ciphertext);
Я использую пакет Baser64 для шифрования и дешифрования строк и прочего.
Работает хорошо, и вы можете использовать Hash-файл, чтобы сделать шифрование еще более безопасным.
npm i --save baser64
Попробуйте использовать пакет 'bcrypt', он поможет вам в шифровании паролей. Если вы хотите шифрование данных. Тогда используйте crypto или node-rsa
Ссылка на пакет npm bcrypt