암호화 기술은 일반적으로 "대칭"과 "비대칭"이라는 두 가지 범주로 나뉩니다.
대칭 암호화:
암호화와 복호화에는 동일한 키가 사용되며 일반적으로 "세션 키"라고 합니다. 이 암호화 기술은 미국 정부 DES에서 사용하는 것과 같이 오늘날 널리 사용됩니다. 암호화 표준은 일반적인 "대칭" 암호화 방법이며 세션 키 길이는 56비트입니다.
비대칭 암호화:
즉, 암호화와 복호화에는 일반적으로 "공개 키"와 "개인 키"라는 두 개의 키가 필요합니다. 그렇지 않으면 둘 다 필요합니다. 암호화된 파일은 열 수 없습니다.
암호화는 시스템에서 자주 사용되는 기능입니다. Node에는 강력한 암호화 기능인 Crypto가 포함되어 있습니다. 간단한 예를 들어 보겠습니다.
1. 암호화 모듈 참조:
var crypto=require('crypto'); var $=require('underscore');var DEFAULTS = { encoding: { input: 'utf8', output: 'hex' }, algorithms: ['bf', 'blowfish', 'aes-128-cbc'] };
기본 암호화 알고리즘 구성 항목:
입력 데이터 형식은 다음과 같습니다. utf8, 출력 형식은 16진수이며
알고리즘은 bf, Blowfish 및 aes-128-abc의 세 가지 암호화 알고리즘을 사용합니다.
2. 구성 항목 초기화:
function MixCrypto(options) { if (typeof options == 'string') options = { key: options }; options = $.extend({}, DEFAULTS, options); this.key = options.key; this.inputEncoding = options.encoding.input; this.outputEncoding = options.encoding.output; this.algorithms = options.algorithms; }
암호화 알고리즘을 구성할 수 있으며, 옵션을 구성하여 다양한 암호화 알고리즘과 인코딩을 사용할 수 있습니다.
3. 암호화 방법 코드는 다음과 같습니다.
MixCrypto.prototype.encrypt = function (plaintext) { return $.reduce(this.algorithms, function (memo, a) { var cipher = crypto.createCipher(a, this.key); return cipher.update(memo, this.inputEncoding, this.outputEncoding) + cipher.final(this.outputEncoding) }, plaintext, this); };
암호화를 사용하여 데이터를 암호화합니다.
4. 복호화 방법 코드는 다음과 같습니다.
MixCrypto.prototype.decrypt = function (crypted) { try { return $.reduceRight(this.algorithms, function (memo, a) { var decipher = crypto.createDecipher(a, this.key); return decipher.update(memo, this.outputEncoding, this.inputEncoding) + decipher.final(this.inputEncoding); }, crypted, this); } catch (e) { return; } };
암호화를 사용하여 데이터를 복호화합니다.
암호화 및 복호화 알고리즘을 실행하려면 밑줄에 있는 Reduce 및 ReduceRight 메서드를 사용하세요.
이 글은 Min Shao가 작성한 알고리즘을 기반으로 작성되었습니다. 길을 떠나는 초보여, 계속 가세요.
위 nodejs 암호화된 Crypto 예제 코드는 모두 편집자가 공유한 내용이므로 참고가 되셨으면 좋겠고, PHP 중국어 홈페이지도 방문해보시길 바랍니다.
더 많은 nodejs 암호화 Crypto 예제 코드 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!