前后端防重复提交

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

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

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

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,提交时带上。

相关推荐
weixin_446122461 小时前
JAVA内存区域划分
java·开发语言·redis
小小小小宇1 小时前
虚拟列表兼容老DOM操作
前端
悦悦子a啊1 小时前
Python之--基本知识
开发语言·前端·python
Piper蛋窝2 小时前
深入 Go 语言垃圾回收:从原理到内建类型 Slice、Map 的陷阱以及为何需要 strings.Builder
后端·go
TT哇2 小时前
JavaEE==网站开发
java·redis·java-ee
安全系统学习2 小时前
系统安全之大模型案例分析
前端·安全·web安全·网络安全·xss
涛哥码咖2 小时前
chrome安装AXURE插件后无效
前端·chrome·axure
OEC小胖胖3 小时前
告别 undefined is not a function:TypeScript 前端开发优势与实践指南
前端·javascript·typescript·web
行云&流水3 小时前
Vue3 Lifecycle Hooks
前端·javascript·vue.js
Sally璐璐3 小时前
零基础学HTML和CSS:网页设计入门
前端·css