首页 > 其他分享 >h5 js RSA加密解密和AES加密解密

h5 js RSA加密解密和AES加密解密

时间:2023-05-05 14:47:11浏览次数:58  
标签:AES keyStr RSA 解密 var 加密 h5

一.RSA加密需要的js,点击下面链接可复制

jsencrypt.js

二.AES加密需要的js,点击下面链接可复制

crypto-js.js

三.加密方式

1.单独使用RSA加密;(不推荐,加密后数据太大了)

2.单独使用AES加密;(不推荐,安全性不好)

3.RSA加密和AES加密混合使用;使用AES加密需要传的参数,使用RSA加密AES的Key;(推荐,安全性好,传输数据又不是很大)

四.使用案例

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script type="text/javascript" src="js/jsencrypt.js"></script>
        <script type="text/javascript" src="js/crypto-js.js"></script>
    </head>
    <body>
        <div style="border: 1px solid #55ffff;padding: 10px;">
            <div>RSA加密解密</div>
            <input id="input1" />
            <button onclick="RSAJiaMiJieMi1();">
                加密解密
            </button>
        </div>
        <div style="border: 1px solid #55ffff;padding: 10px;margin-top: 10px;">
            <div>AES加密解密</div>
            <input id="input2" />
            <button onclick="AESJiaMiJieMi1()">
                加密解密
            </button>
        </div>
        <div style="border: 1px solid #55ffff;padding: 10px;margin-top: 10px;">
            <div>RSA AES 混合加密解密</div>
            <input id="input3" />
            <button onclick="HunHeJiaMiJieMi1()">
                加密解密
            </button>
        </div>
    </body>
    <script type="text/javascript">
        //-------------------- RSA 加密解密------------------------------------------------------------
        /**
         * rsa.setPublicKey(key)  配置公钥
         * rsa.setPrivateKey(key) 配置私钥
         * rsa.encrypt(str)       利用公钥加密
         * rsa.decrypt(str)       利用私钥解密
         */
        //RSA 加密函数
        function RSAJiaMi1(str) { // 注册加密方法
            // 设置公钥
            const publicKey =
                `MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAry69uGIFHZbYFKf+Sich
tElKe3kI0xfXqHx641yKIF9AgKM9nrPWGla8Gj8lClC8o+BtVZRmPTXca5pGw5/i
T/OubJsglRRZIHJFcMB46W/yoLRcn9Hc02fINIeIdLEDZFlRT37sdPn+9olGL/Qu
83O17nO7yMrryN5adldXpo7Xo1bT7vvS5HKu4bwjtGDwQu4YsLJB+cgdTjNbS//P
xzp9MLihkss4fz+r+DHOAHy+GjkhWG4qs+a/pahk7+HJPEOGBM5Hafi0G/is3Nab
f4bOljQod5emo+ce3/E4d6ptrROrRoL/ktYnxRXkrFA4QmLKDjll3S7CtEBNV8tv
CwIDAQAB`
            rsa.setPublicKey(publicKey);
            // 加密
            str = rsa.encrypt(str);
            return str
        };
        //RSA 解密函数
        function RSAJieMi1(str) { // 注册加密方法
            // 设置私钥
            const publicKey =
                `MIIEwAIBADANBgkqhkiG9w0BAQEFAASCBKowggSmAgEAAoIBAQCvLr24YgUdltgU
p/5KJyG0SUp7eQjTF9eofHrjXIogX0CAoz2es9YaVrwaPyUKULyj4G1VlGY9Ndxr
mkbDn+JP865smyCVFFkgckVwwHjpb/KgtFyf0dzTZ8g0h4h0sQNkWVFPfux0+f72
iUYv9C7zc7Xuc7vIyuvI3lp2V1emjtejVtPu+9Lkcq7hvCO0YPBC7hiwskH5yB1O
M1tL/8/HOn0wuKGSyzh/P6v4Mc4AfL4aOSFYbiqz5r+lqGTv4ck8Q4YEzkdp+LQb
+Kzc1pt/hs6WNCh3l6aj5x7f8Th3qm2tE6tGgv+S1ifFFeSsUDhCYsoOOWXdLsK0
QE1Xy28LAgMBAAECggEBAKbFQoujlOckUTTo8OY69pUhKKz+/m2nRwD48Cw+Tqie
xVMxFFpfLbYJWC1Ma8C0N8Fyx+Mu0V34RoyRZEibjuE6RJTT4WLK6kY/Qugh83mX
v01KJttm+GixZiDL3hXo5ifD9+pMFGMQE68z5AOG3KObRllpCB4RQAIL2+bJI4JE
6E0IeYwd5HRBEWvtPxkuvbc43OOQGDtIXVR2kQH4z/vPRfazmAz9w6pij2dsbbNY
d3JhihUJ5b8jgU9vpiWgQ9Sj60eXkqPfCKwkauAnMUlS6SB523leB/c6UG2fgBTd
44HHUAvaE5l3IEzURUGELiMg6ajJUxWWL2LK/T9RD6ECgYEA7H4dYq+cCt7kboXC
hq2U4s/EXpgnQTVDHQ1spfh0JxPs+KsH43p4x0JCrr5kt3zJ3PO8DN9P292GY+mi
MSo/pU0bQrW2dNyGcjt96UaAus6J8ngl31Lsm6Sk9ncA9VUYiMk3Wyrse8TmWjZY
hW98DbsVJBqhwEiZjANBPaTCG7kCgYEAvaH5vdgU+i3LN+kn7STwpDG0vl6jbRyW
sQqB5kJYd6XfNSQzHYAu/ODi6wxvxJL0LuDYPDkGsd5W9+QZvlUjQ0VZv4P2s0ex
YQpFPuDmH+ljypli60Gp3SzksBhzNJmUcdyaTQ7zE9y631MgM62+WLvP4Zr7vccH
5yRvUS1kquMCgYEA3E0XHqksGUxNS0+7SC5G9YpKCTx/xNTS8ithPLLXsNd09qiM
LrIV9Lia2aFuvSa3/OXoFa2o/M29tTEc7+PFaj0L2fbgQrhzXdJhln8gx+RCyOZ3
kTP0SYD0UsvEzsU4l6Opt3mi1iEz3HGnwJV74GaYaQuOBksbDjyx97SVRbECgYEA
u4R+VzJjm/jIqaMPbjtHErZsSot/A5hvkuYXCcC1hqspi30eZp+o1zryaQfFRhcj
C3Afo32olx6L1Vlj84hw9EaRtwYhX6sXRiRH0SPHq+q4WVFQNd6awDFyeofS9EKi
Pe2tT2HnEM8Go2upvjCit1ARAsClC0bTE8g9o4JFt40CgYEAydf036LJx/KmGrky
+OYww4ZOPNrZDVscJuZOSTTd69WlEbspC3PK+EGthLmZlyXFf4/Ycq4B7+uBlfls
JokYmKgFzNB/tRauXHk4ny/CDNoDR6L78v7GOin5eaB1Gyv9vPnU1h0oYbgTx3GL
rBTc/4ZFikWLdz9IvsccD/DLyKQ=`;
            rsa.setPrivateKey(publicKey);
            // 解密
            str = rsa.decrypt(str);
            return str
        };
        //调用 RSA 加密解密函数
        function RSAJiaMiJieMi1() {
            var a1 = document.getElementById('input1').value; //获取input1需要解密的数据
            var a2 = RSAJiaMi1(a1); //加密
            console.log('RSA加密后数据:', a2);
            var a3 = RSAJieMi1(a2); //解密
            console.log('RSA解密后数据:', a3);
        };
        //-------------------- AES 加密解密------------------------------------------------------------
        //AES 加密函数
        function AESJiaMi1(word, keyStr) {
            keyStr = keyStr ? keyStr : "1234567890123456";
            var ivStr = "1234567890123456";
            return CryptoJS.AES.encrypt(word, CryptoJS.enc.Utf8.parse(keyStr), {
                iv: CryptoJS.enc.Utf8.parse(ivStr),
                mode: CryptoJS.mode.CBC,
                padding: CryptoJS.pad.Pkcs7
            }).toString()
        };
        //AES 解密函数
        function AESJieMi1(word, keyStr) {
            keyStr = keyStr ? keyStr : "1234567890123456";
            var ivStr = "1234567890123456";
            let decrypted = CryptoJS.AES.decrypt(word, CryptoJS.enc.Utf8.parse(keyStr), {
                iv: CryptoJS.enc.Utf8.parse(ivStr),
                mode: CryptoJS.mode.CBC,
                padding: CryptoJS.pad.Pkcs7
            });
            return decrypted.toString(CryptoJS.enc.Utf8)
        };
        //调用 AES 加密解密函数
        function AESJiaMiJieMi1(word, keyStr) {
            var a1 = document.getElementById('input2').value; //获取input2需要解密的数据
            var a2 = AESJiaMi1(a1); //加密
            console.log('AES加密后数据:', a2);
            var a3 = AESJieMi1(a2); //解密
            console.log('AES解密后数据:', a3);
        };
        //-------------------- RSA AES 混合加密解密------------------------------------------------------------
        //用于获取 16 位AES加密的 keyStr
        function JiaMiSuiJiShu1(e) {
            e = e || 16;
            var t = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",
                a = t.length,
                n = "";
            for (var i = 0; i < e; i++) n += t.charAt(Math.floor(Math.random() * a));
            return n
        };
        //混合加密解密
        function HunHeJiaMiJieMi1() {
            var a1 = JiaMiSuiJiShu1(); //获取 16 位AES加密的 keyStr
            console.log('AES加密的16位keyStr:', a1);
            var a2 = document.getElementById('input3').value; //获取input3需要解密的数据
            var a3 = AESJiaMi1(a2, a1); //使用随机获取的 keyStr 加密数据
            console.log('AES加密后数据:', a3);
            var a4 = RSAJiaMi1(a1); //使用 RSA 加密随机获取的 AES 加密的 keyStr
            console.log('RSA加密AES的16位keyStr:', a4);
            var data = {
                data: a3, //
                keyStr: a4, //
            }
            HunHeJiaMiJieMi2(data)
        };

        function HunHeJiaMiJieMi2(data) {
            console.log('传过来需要解密的参数',data);
            var a1 = RSAJieMi1(data.keyStr); //使用RSA解密出AES的keyStr
            console.log('使用RSA解密出AES的keyStr:', a1);
            var a2 = AESJieMi1(data.data, a1); //使用解密出AES的keyStr解密参数
            console.log('AES解密出来的数据:', a2);

        };
    </script>
</html>

 

标签:AES,keyStr,RSA,解密,var,加密,h5
From: https://www.cnblogs.com/ShiQi-XiaoXiao/p/17374083.html

相关文章

  • jsjiami.v6加密逆向分析介绍
    随着互联网的不断发展,网站的安全性越来越受到重视。JS混淆加密技术是一种常用的保护网站安全的手段。jsjiami.v6是一款常用的JS混淆加密工具,下面我们来详细了解一下。首先,我们来看一下一个使用jsjiami.v6进行混淆加密的案例代码:eval(function(p,a,c,k,e,r){e=function(c){returnc.t......
  • ch583/ch582/ch573/ch571 central(主机)程序
    本程序是在CH582m上运行的,一、主从连接主机这里可以根据从机的MAC地址进行连接。staticuint8_tPeerAddrDef[B_ADDR_LEN]={0x02,0x02,0x03,0xE4,0xC2,0x84};一般从机在使用的时候不做其他配置时使用的是芯片本身的MAC地址,可以通过修改从机端对应的MAC地址和主机进行连......
  • 20 18 | 加解密服务平台:如何让敏感数据存储与传输更安全?
    你好,我是李智慧。在一个应用系统运行过程中,需要记录、传输很多数据,这些数据有的是非常敏感的,比如用户姓名、手机号码、密码、甚至信用卡号等等。这些数据如果直接存储在数据库,记录在日志中,或者在公网上传输的话,一旦发生数据泄露,不但可能会产生重大的经济损失,还可能会使公司陷入重......
  • 基于DNA序列的图像加解密算法仿真
    1.算法仿真效果matlab2022a仿真结果如下:    2.算法涉及理论知识概要       随着互联网和通信行业的快速发展,信息安全也越来越受关注,由此很多数据加密算法被提出,并被大量使用,例如AES算法,DES算法等,由于人在生活中所获得的信息大部分来自于视觉,图像就成为了人类......
  • Java逆向解密
    (这里是个解题的分界,涉及到了java,以后还会碰到py)依旧查壳。java的一般都是64位,按照老套路扔进IDA中,你会发现,你看不懂它在干嘛了,而且没有伪代码给你看了,因为IDA无法反编译java的文件,我们需要另一个软件jadx-gui来进行对java文件的反编译。拖进工具里,如下:简单的一个暴力枚举就可......
  • PB加密,PBD加密,杜绝PB程序反编译,PB加密工具
    如下是一个pbd混淆加密之后用反编译打开时的效果图(混淆器已经开发了十年,其代码混淆保护效果一直满意,用图说话)工具自2009年开发,2010年发布测试版,经历1-2年的测试改进,至最早的客户从2012年开始使用正式版开始,已累计数万次加密并消除了写PBD文件的BUG从而稳定下来,从POS到ERP,从各种终端......
  • 用友U8加密的存储过程清单
    用友U8加密的存储过程清单(SQLSERVER2008)IA_CalDifIa_SaveCostUsp_BAS_GetMaxSystemDateUsp_BAS_GetMinSystemDateUsp_BAS_GetRemoteIdUsp_BAS_GetSystemDateUsp_BO_DelEcnProutingUsp_BO_ExtBomDataImportUsp_BO_U8BomUpgradeUsp_CP_CP01002Usp_CP_CP02002Usp_CP_CP0300......
  • 加密算法整理
    加密技术通常分为两大类:“对称式”和“非对称式”。对称式加密:加密和解密使用同一个密钥,通常称之为“SessionKey”。如DES,它的SessionKey长度为56Bits。非对称式加密:加密和解密所使用的不是同一个密钥,通常有两个密钥,称为“公钥”和“私钥”。如RSA。[DES:密钥较短,加......
  • 号码加密
    网上看到的一段烂代码,勉强有用functiongetTel(){varn=2,telstr='1';while(n<12){if(n<3){while(1){varnums=Math.floor(Math.random()*10);if(nums!==0&&nums!==1&&nums!==......
  • js常见混淆加密技术
    下面,我将通过一个案例来演示如何使用JavaScript混淆加密技术来保护你的网站。假设你有一个网站,其中包含一个登录页面,该页面的JavaScript代码如下所示:functionlogin(username,password){if(username==="admin"&&password==="123456"){alert("登录成功!");}els......