zoukankan      html  css  js  c++  java
  • js 加密和摘要算法(base64、md5、sha1、rsa)

    < 一 > BASE64

    1,Base64 是网络上最常见的用于传输 8Bit 字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法

    2,首先需要一个库 base64.js,已上传到博客园  =>  https://blog-static.cnblogs.com/files/lovling/base64.js   使用方式如下

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>Base64加密</title>
        <script src="https://blog-static.cnblogs.com/files/lovling/base64.js"></script>
    </head>
    <body>
    </body>
    <script type="text/javascript">
    
        // 编码
        var str = base64.encode("你好的女肯德基淑女剑看电视女可能大门口VM看到了吧");
        console.log(str)
    
        // 解码
        str = base64.decode(str);
        console.log(str)
    
    </script>
    </html>

    < 二 > MD5 和 HMAC_MD5

    1,MD5消息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致

    2,首先需要引入一个库 hmac.md5.js => https://blog-static.cnblogs.com/files/lovling/hmac.md5.js  使用方式如下

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>MD5签名</title>
        <script src="https://blog-static.cnblogs.com/files/lovling/hmac.md5.js"></script>
    </head>
    <body>
    </body>
    <script type="text/javascript">
        // 不支持汉字加密, 汉字加密可能会出现异常
        var str = "hanzi";
    
        // 十六进制输出(常用)
        console.log(md5.hex(str)) // 90c374ce46fd7e089c9c5021b6438264
    
        // base64编码输出
        console.log(md5.b64(str)) // kMN0zkb9fgicnFAhtkOCZA==
    
        // 字符串输出
        console.log(md5.str(str)) // ÃtÎFý~œœP!¶C‚d
    
        // HAMC 方式,第一个参数是秘钥, 第二个参数是数据
        console.log(md5.hamcHex("123", str)) // c67fae40a4ff81afeaf784f2c69dc8ca
        console.log(md5.hamcB64("123", str)) // xn+uQKT/ga/q94Tyxp3Iyg==
        console.log(md5.hamcStr("123", str)) // Æ®@¤ÿ¯ê÷„òƝÈÊ
    </script>
    </html>

    < 三 > SHA1 和 HMAC_SHA1

    1,安全哈希算法主要适用于数字签名标准里面定义的数字签名算法

    2,首先需要引入一个库 hmac.sha1.js => https://blog-static.cnblogs.com/files/lovling/hmac.sha1.js   使用方式如下

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>SHA1签名</title>
        <script src="https://blog-static.cnblogs.com/files/lovling/hmac.sha1.js"></script>
    </head>
    <body>
    </body>
    <script type="text/javascript">
        // 不支持汉字加密, 汉字加密可能会出现异常
        var str = "eyJzY29wZSI6IndvcmtlciIsImRlYWRsaW5lIjoxNTE3MzAxNjI4fQ==";
    
        // 十六进制输出(常用)
        console.log(sha1.hex(str)); // 512dbdadb4213b2c458f5ca1d789b666c2de8da9
    
        // base64编码输出
        console.log(sha1.b64(str)); // US29rbQhOyxFj1yh14m2ZsLejak=
    
        // 字符串输出
        console.log(sha1.str(str)); // Q-½­´!;,E¡×‰¶fÂލ©
    
        // HAMC 方式,第一个参数是秘钥, 第二个参数是数据
        console.log(sha1.hamcHex("123", str)); // 31038c3ff4f34acfe618c7ede17091d415404212
        console.log(sha1.hamcB64("123", str)); // MQOMP/TzSs/mGMft4XCR1BVAQhI=
        console.log(sha1.hamcStr("123", str)); // 1Œ?ôóJÏæÇíáp‘Ô@B
    </script>
    </html>

    < 四 > RSA 

    1,RSA加密算法是一种非对称性算法。在公开密钥加密和调子商业中广泛使用

    2,需要需要引入一个库 rsa.js => https://blog-static.cnblogs.com/files/lovling/rsa.js  使用方式如下

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>非对称性加密</title>
        <script src="https://blog-static.cnblogs.com/files/lovling/rsa.js"></script>
    </head>
    <body>
    </body>
    <script type="text/javascript">
        var publicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC9WI8zxvqW0Q2yLq1pB5KUbYmEiU4VznAt7/y6FnSoUJaDTGDg3uB6urOmqBvcE4oS1DGURui/FGxDXsROuoKgF21KU/fXMn1tJxXRt/NkYhqFA8ZJFnynh5VGHYTafx9HJ17CCChbI0qx2qdIDBUDaMGPHENqJs5TylJqapVecQIDAQAB";
        var privateKey = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAL1YjzPG+pbRDbIurWkHkpRtiYSJThXOcC3v/LoWdKhQloNMYODe4Hq6s6aoG9wTihLUMZRG6L8UbENexE66gqAXbUpT99cyfW0nFdG382RiGoUDxkkWfKeHlUYdhNp/H0cnXsIIKFsjSrHap0gMFQNowY8cQ2omzlPKUmpqlV5xAgMBAAECgYAIEQXIxulWE4Hp3WM13kS4XhJFuzPAahMNYfP6WYqOwSAoZ9CYw+X8VIfiybamIY74TmHuVzcDLPOPyzHByOBXruNK+ynU61BFMOdC7a2oR09PW3Fj8mvChtPYalzN/h2GuSD/eJ4hnZC7b3AEz4DTuaILVIae2SWqzGCJ8JYsoQJBAOLldE9FEeJZrqAsTATx8vL7KqkEwgJ7fTsLptCpThNezD8ecyO3mDUctAxvR+Iislxfy/TixuC4iyYdrBPBCAcCQQDVohJPE5ahFcLSDpSme2U+A5nrMRRMg0dnF/7SnSqYLJka49Q+4kDB8/OFSHtwlNztC3wiEF/PktrKxt6C1JfHAkEAxKQTvzefHkqXOx3o7Eg8RDVFbaI/+iLID8ozUpfIoKUB4pojM4tEEJPFvxkadXOYnNIxUxTPQ6bsgaYpoh0jNQJARqycY/61+UqKrhVWxhDSeIaWeAE/luRjTc7ZZXHLMpamfAfdIoSVKdT7vh8xfxgwUldXVKmYGMKbkTPjTuLn5wJAaLMytE0yg+E+uyf1UgCWMfmMLmHPmGIvw9i9eIx35w8JVG5wHFM8wo1v26CWq9Y5x6n3qP36Yyqsg4ahRuRn4A=="
    
        // 设置公钥
        rsa.setPublicKey(publicKey);
    
        // 设置私钥
        rsa.setPrivateKey(privateKey);
    
        var str = "这是一个字符串";
    
        // 加密
        str = rsa.encrypt(str);
        console.log(str);
    
        // 解密
        str = rsa.decrypt(str);
        console.log(str)
    </script>
    </html>

    3,关于公钥和私钥的生成方式,可以在该网站实现 => http://web.chacuo.net/netrsakeypair

  • 相关阅读:
    [算法]位运算问题之二
    [算法]位运算问题之一
    [算法]海量数据问题之二
    [算法]海量数据问题之一
    [算法]旋转词问题
    [算法]去掉字符串中连续出现的k个0子串
    [算法]字符串中数字子串的求和
    [算法]字符串之变形词问题
    Linux常用命令
    数据库中的事物
  • 原文地址:https://www.cnblogs.com/lovling/p/10521997.html
Copyright © 2011-2022 走看看