• 前端对用户名密码加密处理,后端解密


    一. 正常表单提交如图,可以看见输入的用户名密码等

    在这里插入图片描述

    二. 使用crypto-js.min.js进行前端加密处理

    js资源地址链接:https://pan.baidu.com/s/1kfQZ1SzP6DUz50D–g_ziQ
    提取码:1234
    前端代码

    <script type="text/javascript" src="/js/crypto-js.min.js"></script>
    <script type="text/javascript">
    function encrypt(str, key, iv) {
    	//密钥16位 
    	var key = CryptoJS.enc.Utf8.parse(key); 
    	//加密向量16位 
    	var iv = CryptoJS.enc.Utf8.parse(iv); 
    	var encrypted = CryptoJS.AES.encrypt(str, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }); 
    	return encrypted; 
    	
    }
    
    
    </script>
    
    <script>
        layui.use('form', function () {
            var form = layui.form;
            form.render();
            form.on('submit(LAY-user-login-submit)', function (data) {
            //表单可使用var data = $(“form”).serialize();
                var field = data.field;
                var jsonstr=JSON.stringify(field);
                var enjsonstr=encrypt(jsonstr,'abcdefgh12345678','abcdefgh12345678');
                var enstr="'"+enjsonstr+"'";
                $.post("{:url('admin/site/login')}",{key:enstr}, function (ret) {
                	//成功
                    if (ret.code == 0) {
                        layer.msg(ret.msg, { time: 1000 }, function () {
                            window.location.href = ret.url;
                        })
                    } else {
                        layer.msg(ret.msg, { time: 1000 });
                        setTimeout(function (){
     
    						 window.location.reload();
    						}, 2000);
                        
                        
                    }
                });
            });
        });
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    后端使用php获取数据

    $input = input("request.", '', 'trim'); 
    $obj=get_object_vars(decrypt($input['key'],'abcdefgh12345678','abcdefgh12345678'));
    unset($input['key']);
    $input=array_merge($input,$obj);
    
    • 1
    • 2
    • 3
    • 4

    后端解密方法如下

    function decrypt($data, $key, $iv) {
    	$decrypted = openssl_decrypt(base64_decode($data), 'AES-128-CBC', $key, true, $iv); 
    	$json_str = rtrim($decrypted, "\0");
    	return json_decode($json_str); 
    	
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    部署zookeeper集群
    重装系统后新建文本文档打不开怎么办
    手机中常用的传感器
    【Oracle】Oracle系列十八--Oracle RAC
    数据结构 | 树和二叉树的基本概念和性质
    [Model.py 01]Modification for creating terrain matrix.
    卡码网语言基础课 | 12. 位置互换
    YOLOv3&YOLOv5输出结果说明
    提供CY系列菁染料CY3、CY5、CY5.5、CY7、CY7.5,ICG,荧光素FITC 系列染料标记吉兰糖胶Gellan gum
    vscode插件开发之 - TestController
  • 原文地址:https://blog.csdn.net/sang521jia/article/details/134429447