码迷,mamicode.com
首页 > 编程语言 > 详细

HTML5 加密和摘要算法(base64,md5, sha1,rsa)

时间:2019-03-13 12:33:47      阅读:269      评论:0      收藏:0      [点我收藏+]

标签:pre   isl   表示   pbc   就是   fmm   iba   class   .sh   

< 一 > 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

 

HTML5 加密和摘要算法(base64,md5, sha1,rsa)

标签:pre   isl   表示   pbc   就是   fmm   iba   class   .sh   

原文地址:https://www.cnblogs.com/lovling/p/10521997.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!