• nodejs加密Crypto简单例子


    加密技术通常分为两大类:“对称式”和“非对称式”。

    对称式加密:

    就是加密和解密使用同一个密钥,通常称之为“Session Key ”这种加密技术在当今被广泛采用,如美国政府所采用的DES加密标准就是一种典型的“对称式”加密法,它的Session Key长度为56bits。
    非对称式加密:

    就是加密和解密所使用的不是同一个密钥,通常有两个密钥,称为“公钥”和“私钥”,它们两个必需配对使用,否则不能打开加密文件。

    加密为系统中经常使用的功能,node自带强大的加密功能Crypto,下面通过简单的例子进行练习。

    1、加密模块的引用:

    var crypto=require('crypto');
    var $=require('underscore');
    var DEFAULTS = {
        encoding: {
            input: 'utf8',
            output: 'hex'
        },
        algorithms: ['bf', 'blowfish', 'aes-128-cbc']
    };

    默认加密算法配置项:

    输入数据格式为utf8,输出格式为hex,

    算法使用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;
    }

    加密算法可以进行配置,通过配置option进行不同加密算法及编码的使用。

    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);
    };

    使用crypto进行数据的加密处理。

    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;
        }
    };

    使用crypto进行数据的解密处理。

    通过underscore中的reduce、reduceRight方法,进行加密和解密的算法执行。

    本文根据民少编写的算法进行编写,如有不足之处,敬请原谅。菜鸟在路上,继续前进。

  • 相关阅读:
    “LM/w3svc/1/root /***” 别名已存在
    Dawn of a New Day
    线程池(java.util.concurrent.ThreadPoolExecutor)的使用
    放心走吧,谷歌中国
    实现MySQL允许远程连接
    Google Engineer Gets $6 Million For Not Going To Facebook
    mysql主从同步出现Slave_IO_Running: Connecting的解决思路
    解决eclipse/sts加入@Controller注解后alt+/快捷键的提示功能失效
    Maven异常:Missing artifact org.slf4j:slf4japi:jar:1.7.25以及properties标签作用
    eclipse和sts使用alt+/代码提示,有两个相同的提示
  • 原文地址:https://www.cnblogs.com/diaosizhang/p/4111871.html
Copyright © 2020-2023  润新知