ホームページ >ウェブフロントエンド >フロントエンドQ&A >JavaScriptの暗号化方式にはどのようなものがありますか?

JavaScriptの暗号化方式にはどのようなものがありますか?

青灯夜游
青灯夜游オリジナル
2021-04-25 18:35:037489ブラウズ

暗号化メソッドには次のものが含まれます: 1. 「window.btoa(value)」ステートメントを使用して暗号化; 2. hex_md5()、b64_md5()、str_md5() およびその他の関数を使用して暗号化; 3. sha1 を使用() 関数を使用して暗号化する; 4. エスケープ() 関数を使用して暗号化する; 5. AES を使用して暗号化する。

JavaScriptの暗号化方式にはどのようなものがありますか?

このチュートリアルの動作環境: Windows7 システム、JavaScript バージョン 1.8.5、Dell G3 コンピューター。

#1. 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>

2. MD5 暗号化 (不可逆)

MD5 について:

MD5.js は、フロントエンドの JS 暗号化によってユーザー情報やパスワードなどの個人情報を暗号化するツールであり、プラグインとも呼ばれます。

MD5 には 6 つの暗号化方式があります:

1、hex_md5(値)
2、b64_md5(値)
3、str_md5(値)
4、 hex_hmac_md5(キー、データ)
5、b64_hmac_md5(キー、データ)
6、str_hmac_md5(キー、データ)

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>

3. sha1 暗号化 (不可逆)

ここには sha1.js のダウンロード アドレスが見つからないため、オンライン ファイルを見つけてください。必要に応じて、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>

4. 文字列のエンコードとデコード

JS 関数エスケープ() と unescape() を使用してエンコードとデコードを行います。それぞれ文字列

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

5. AES/DES暗号化と復号

##crypto-js.jsのダウンロード 導入URLはクリックしてダウンロード

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

[注意]:暗号化時に文字列に変換されます。復号化するときは、utf8 の形式を使用する必要があります。

#その他

#RSA 暗号化

#[推奨学習:

JavaScript 上級チュートリアル

]

以上がJavaScriptの暗号化方式にはどのようなものがありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。