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

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

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

js资源地址链接:https://pan.baidu.com/s/1kfQZ1SzP6DUz50D--g_ziQ

提取码:1234

前端代码

javascript 复制代码
<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>

后端使用php获取数据

php 复制代码
$input = input("request.", '', 'trim'); 
$obj=get_object_vars(decrypt($input['key'],'abcdefgh12345678','abcdefgh12345678'));
unset($input['key']);
$input=array_merge($input,$obj);

后端解密方法如下

php 复制代码
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); 
	
}
相关推荐
恋猫de小郭42 分钟前
Redis 作者反驳「中国模型之所以强,是因为通过 API 蒸馏了美国模型」
前端·人工智能·ai编程
Darling噜啦啦1 小时前
Canvas 游戏开发与数据可视化实战:从飞机大战到 ECharts 报表
前端·echarts·canvas
OpenTiny社区1 小时前
这次更新太良心!GenUI SDK v1.2.0 轻量化 + 稳流式 + 超强 Playground
前端·vue.js·ai编程
梨子同志1 小时前
WebGL test
前端
程序员黑豆1 小时前
AI全栈开发系列开篇:从Java全栈到AI应用实战
前端·ai编程·全栈
yangyj1 小时前
从 PDR 到落地:用 Codex 完成一次 Rspack 升级
前端
程序员鱼皮1 小时前
提示词工程已死,Loop Engineering 称王!保姆级教程 + 项目实战
前端·后端·ai编程
小爷毛毛_卓寿杰1 小时前
给 Embedding 模型也加一块“游乐场“—— Xinference 是怎么把 vector 变成肉眼可见的体验的
前端
忆江南1 小时前
iOS 性能优化全面详解
前端
lichenyang4531 小时前
HAP / HAR / HSP 到底啥区别?顺带把「导入」那点疑惑讲清楚
前端