前端怎么用js 进行crypto.js的加密和解密?

微信受权时会用到加解密比较多,当后端写好连接,让前端去获取惟一标识openid,就能够实现微信受权,可是为了安全起见,最好不要把获取到的信息裸露在网址上面,因此后端须要加密用户的信息,让前端去解密。css

较为安全的加密方式:前端

des加密方式vue

CBC是modenpm

PKCS5Padding是padding schemes后端

解密前须要后端提供的是加密前数据(方便去对照解出来数据是否正确)加密后数据秘钥,还有iv偏移量,不过通常都要本身一个一个的去试。我用过的就是des/CBC/Paddingkey数组

步骤以下:安全

能够用npm进行下载,而后能够编写一个加解密的工具类微信

npm install crypto-js
复制代码

1.引入crypto.js插件工具

<script src="https://cdn.bootcss.com/crypto-js/3.1.9-1/crypto-js.min.js"></script>
复制代码

2.就是要解密执行的代码加密

<script>
        window.onload = function () {
            //须要加密的内容
            let value = '加密地址'
            let jiami = escape(value)
            console.log('加密数据:',jiami)
            let str1 = encryptByDES(jiami);
            console.log('加密后的数据:',str1.toString().toUpperCase())
            let str2 = encodeURI(decryptByDESModeEBC(str1));
            console.log('解密后的数据:',str2)
        }
        //加密的私钥 
        注意:key和iv咱们均可以更换,可是须要保证的是加解密的key和iv保持一致
        var key = '秘钥';
        var iv = '偏移量值'
        // DES加密
        function encryptByDES(message) {
            //把私钥转换成16进制的字符串
            var keyHex = CryptoJS.enc.Utf8.parse(key);
            //模式为ECB padding为Pkcs7
            var encrypted = CryptoJS.DESede.encrypt(message, keyHex, {
                iv: iv,
                mode: CryptoJS.mode.CBC,
                padding: CryptoJS.pad.Paddingkey
            });
            //加密出来是一个16进制的字符串
            // var result_value = CryptoJS.enc.Base64.parse(result_value)
            // // var word2 = RSAdecrypt(parseStr)
            // var parseStr = words.toString(CryptoJS.enc.UTF-8)
            return encrypted.ciphertext.toString();
        }
        //DES  ECB模式解密
        function decryptByDESModeEBC(ciphertext) {
            //把私钥转换成16进制的字符串
            var keyHex = CryptoJS.enc.Utf8.parse(key);
            //把须要解密的数据从16进制字符串转换成字符byte数组
            var decrypted = CryptoJS.DESede.decrypt({
                ciphertext: CryptoJS.enc.Hex.parse(ciphertext)
            }, keyHex, {
                iv: iv,
                mode: CryptoJS.mode.CBC,
                padding: CryptoJS.pad.Paddingkey
            });
            //以utf-8的形式输出解密事后内容
            // var value = CryptoJS.enc.Base64.parse(value)
            var result_value = decrypted.toString(CryptoJS.enc.Utf8)
            // var result_value = CryptoJS.enc.Base64.parse(result_value)
            // // var word2 = RSAdecrypt(parseStr)
            // var parseStr = words.toString(CryptoJS.enc.UTF-8)
            return result_value
        }
    </script>
复制代码

我在使用vuejs作一个受权功能的时候就用到过,发现这个crypto-js仍是挺不错的。

相关文章
相关标签/搜索