前后端防重复提交

数据重复提交是一个大忌,会带来无效数据,应该在前端和后端都建议检测防范。

前端一般是按钮按下触发数据提交,如果用户鼠标操作习惯不好,或者鼠标或系统设置问题会导致鼠标连击,如果前端不做相关处理,可能会触发多次提交操作。

那么怎么处理为好呢?首先,按下按钮按下事件触发函数中,可以考虑禁用按钮,等待提交正常返回后,重置页面填报项信息,然后再启用按钮,如果是错误返回,那么提示错误信息,可以不重置页面填报,然后再启用按钮。

javascript 复制代码
$("#button_submit").click(()=>{
	validate_input();
	$("#button_submit").attr("disabled",true); 
	axios.post(ifurl,jsondata).then(res=> {
		if (res.data.code=="200") {
			alert("提交成功");
			reset_input();
			$("#button_submit").attr("disabled",false);
			}
		else { alert(res.data.msg); $("#button_submit").attr("disabled",false); }
		}).catch(err => { alert("后端服务器错,请稍后再提交"); $("#button_submit").attr("disabled",false); });
	});

当然后端也不能盲目信任前端,还是要采取措施防止前端重复提交无效数据。

javascript 复制代码
...
var lastpost=[];
...
app.post("/postargs", express.json(), (req, res) => {
	let thispt=Date.now();
	let chktime=lastpost.find(item=>(item.uid=req.session.user.userid));
	if (chktime==undefined) { lastpost.push({uid:req.session.user.userid,lastpt:thispt}) }
	else {
		if (thispt<chktime.lastpt+500) return(res.json({"msg":"拒上次提交不到半秒,疑似误连击,暂不接收本次提交,有疑问请重新提交"}))
		else { chktime.lastpt=thispt; }
		}

例子中是拒绝半秒以内的相同用户的提交,可以根据具体场景调整策略,非登录情况,可以考虑进入页面时,向服务器申请获得一个短时间内有效的ReqID,提交时带上。

相关推荐
卤代烃7 小时前
🦾 可为与不可为:CDP 视角下的 Browser 控制边界
前端·人工智能·浏览器
_XU8 小时前
AI工具如何重塑我的开发日常
前端·人工智能·深度学习
C_心欲无痕8 小时前
vue3 - defineExpose暴露给父组件属性和方法
前端·javascript·vue.js·vue3
鹿人戛8 小时前
HarmonyOS应用开发:相机预览花屏问题解决案例
android·前端·harmonyos
用户47949283569158 小时前
性能提升 40 倍!实战 PostgreSQL FDW 解决微服务跨库查询难题
数据库·后端
萌萌哒草头将军8 小时前
绿联云 NAS 安装 AudioDock 详细教程
前端·docker·容器
计算机毕设VX:Fegn08959 小时前
计算机毕业设计|基于springboot + vue宠物医院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
GIS之路9 小时前
GIS 数据转换:使用 GDAL 将 GeoJSON 转换为 Shp 数据
前端
朴shu9 小时前
Luckysheet 远程搜索下拉 控件开发 : 揭秘二开全流程
前端
Victor35610 小时前
Hibernate(9)什么是Hibernate的Transaction?
后端