【JavaWeb】jsp页面中表单重复提交的三种情况

本文介绍了JavaWeb中表单重复提交的三种情况:请求转发后刷新页面、网络延迟导致的多次点击提交、浏览器回退后重新提交,并提出了相应的解决方案。针对这些情况,可以通过将请求转发改为请求重定向,以及使用Kaptcha验证码来避免重复提交。详细介绍了Kaptcha的使用步骤,包括导入jar包、配置Servlet、显示验证码图片以及服务端验证。
摘要由CSDN通过智能技术生成

情况一

如通过regist.jsp页面提交用户名和密码申请注册,若注册成功,则将用户数据保存到数据库,并通过请求转发跳转到success.jsp页面。

此时在跳转后按F5刷新当前页面,则数据库会多次添加重复记录。原因是因为请求转发其本质是一次请求,而F5会导致浏览器重复提交最后一次请求,即向Servlet请求注册。

情况二

用户正常提交表单,但由于网络原因迟迟没有收到响应,因此用户多次点击提交。

情况三

用户正常提交表单,服务器正常响应,但是提交完成后,用户回退浏览器重新提交。

解决方案

对于情况一来说,通过在Servlet程序中将请求转发改为请求重定向即可解决。

对于情况二、情况三来说,通过验证码解决。服务端的jsp页面会随机生成一个验证码,并将其保存在Session域中。第一次提交表单时Servlet程序会取出验证码与发来的请求作比较并删除,此时验证码相同,允许操作。后来提交表单会因为服务端的验证码变成了null,而导致验证码与请求中的验证码不一致,使得操作被阻止。

Kaptcha

可以通过谷歌Kaptcha完成验证码功能,下载链接在文章末尾。

使用步骤:

1.导入jar包;

2.在web.xml配置用于生成验证码的Servlet程序,注意这个Servlet程序在jar包中已经写好了;

3.在表单中通过img标签显示验证码图片并使用;

4.服务端获取验证码与客户端发来的验证码作比较去使用。

protected void login(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
	//获取并删除Session域中的验证码
	String token = (String)request.getSession().getAttribute(KAPTCHA_SESSION_KEY);//key可以在Kaptcha的Constants文件夹找到
	request.getSession().removeAttribute(KAPTCHA_SESSION_KEY);
	//获取客户端发来的验证码
	String code = request.getParameter("code");
	//获取用户名
	String username = request.getParameter("username");
	//比较
	if (token != null && token.equalsIsIgnoreCase(code)) {
		//保存到数据库
	} else {
		System.out.println("请不要重复提交");
	}
}

下载链接

Kaptcha下载链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

The Gao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值