首頁 >web前端 >前端問答 >javascript加密方法有哪些

javascript加密方法有哪些

青灯夜游
青灯夜游原創
2021-04-25 18:35:037489瀏覽

加密方法有:1、使用「window.btoa(值)」語句進行加密;2、使用hex_md5()、b64_md5()、str_md5()等函數進行加密;3、使用sha1()函數進行加密;4、使用escape()函數加密;5、利用AES加密。

javascript加密方法有哪些

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

一、base64加密

範例

<html>
    <head>
        <title>前端的base64使用方法</title>
    </head>
    <body>
    </body>
<script>
var str = "hello";
var str64 = window.btoa("hello");
console.log("字符串是:"+str);
console.log("经base64编码后:"+str64);
console.log("base64解码后:"+window.atob(str64));
</script>
</html>

二、MD5加密(不可逆)

關於MD5:
MD5.js是透過前台js加密的方式對使用者訊息,密碼等私密資訊進行加密處理的工具,也可稱為插件。

MD5共有6種加密方法:
1,  hex_md5(value)
2,  b64_md5(value)
3, str_md5(value)
4 ,  hex_hmac_md5(key, data)
5,  b64_hmac_md5(key, data)
6,  str_hmac_md5(key, data)

md5代碼下載地址——點此下載

下載好了用script 標籤引入使用

<script src="md5/md5.js"></script>"></script>
    <script>
        var code = "123456";
        var username = "123456";
        var password = "123456";
        var str1 = hex_md5("123456");
        var str2 = b64_md5("123456");
        var str3 = str_md5("123456");
        var str4 = hex_hmac_md5(code,code);
        var str5 = b64_hmac_md5(username,username);
        var str6 = str_hmac_md5(password,password);
        console.log(str1);            // e10adc3949ba59abbe56e057f20f883e
        console.log(str2);            // 4QrcOUm6Wau+VuBX8g+IPg
        console.log(str3);            // áÜ9IºY«¾VàWò��>
        console.log(str4);            // 30ce71a73bdd908c3955a90e8f7429ef
        console.log(str5);            // MM5xpzvdkIw5VakOj3Qp7w
        console.log(str6);            // 0Îq§;Ý��9U©��t)ï
</script>

三、sha1加密(不可逆)

這裡沒找到sha1.js下載地址,所以在bootcdn中找在線文件到引入,所需的可自行從bootcdn下載

<script src="https://cdn.bootcss.com/js-sha1/0.6.0/sha1.js"></script>
<script type="text/javascript">
        var sha1_1 = sha1("mosquito~");
        console.log(sha1_1);
        var sha1_2 = sha1("admin:1001");
        console.log(sha1_2);
</script>

四、編碼和解碼字串

使用JS函數的escape()和unescape(),分別是編碼和解碼字串

<script type="text/javascript">
      var escape1 =escape("我的名字是:mosquito~");//编码
      console.log(escape1);
      var unescape1 = unescape(escape1); //解码
      console.log(unescape1);
</script>

五、AES/DES加密解密

下載crypto-js.js 引入使用網址是點擊下載

var aseKey = "12345678"     //秘钥必须为:8/16/32位
var message = "80018000142";
//加密
var encrypt = CryptoJS.AES.encrypt(message, CryptoJS.enc.Utf8.parse(aseKey), {
  mode: CryptoJS.mode.ECB,
  padding: CryptoJS.pad.Pkcs7
}).toString();
console.log(encrypt);    //VKrZlqykem73x8/T2oCfCQ==

//解密
var decrypt = CryptoJS.AES.decrypt(encrypt, CryptoJS.enc.Utf8.parse(aseKey), {
  mode: CryptoJS.mode.ECB,
  padding: CryptoJS.pad.Pkcs7
}).toString(CryptoJS.enc.Utf8);
console.log(decrypt);    //80018000142

【註】:加密的時候必須轉成字串使用toString。解密的時候 必須使用utf8的格式

其他

RSA加密

#【推薦學習:javascript高階教學

以上是javascript加密方法有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn