商城网站建设运营合同,wordpress 文件下载漏洞,网站制作价格推 荐,网页模板网站有哪些1. 表单重复提交之验证码
1.1 表单重复提交三种常见情况
提交完表单。服务器使用请求转来进行页面跳转。这个时候#xff0c;用户按下功能键 F5#xff0c;就会发起最后一次的请求。造成表单重复提交问题。解决方法#xff1a;使用重定向来进行跳转用户正常提交服务器用户按下功能键 F5就会发起最后一次的请求。造成表单重复提交问题。解决方法使用重定向来进行跳转用户正常提交服务器但是由于网络延迟等原因迟迟未收到服务器的响应这个时候用户以为提交失败就会着急然后多点了几次提交操作也会造成表单重复提交。用户正常提交服务器。服务器也没有延迟但是提交完成后用户回退浏览器。重新提交。也会造成表单重复提交
2. 谷歌kaptcha图片验证码的使用
2.1使用步骤
导入谷歌验证码的jar包 kaptcha-2.3.2.jar 在web.xml中去配置用于生成验证码的Servlet程序
servlet
servlet-nameKaptchaServlet/servlet-name
!--com.google.code.kaptcha.servlet.KaptchaServlet,是jar包提供的--
servlet-classcom.google.code.kaptcha.servlet.KaptchaServlet/servlet-class
/servlet
servlet-mapping
servlet-nameKaptchaServlet/servlet-name
url-pattern/kaptcha.jpg/url-pattern
/servlet-mapping在表单中使用 img 标签去显示验证码图片并使用它
form actionhttp://localhost:8080/tmp/registServlet methodget
用户名input typetext nameusername br
验证码input typetext stylewidth: 80px; namecode
img srchttp://localhost:8080/tmp/kaptcha.jpg alt stylewidth: 100px; height: 28px; br
input typesubmit value登录
/form在服务器获取谷歌生成的验证码和客户端发送过来的验证码比较使用。
Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
// 获取 Session 中的验证码
String token (String) req.getSession().getAttribute(KAPTCHA_SESSION_KEY);
// 删除 Session 中的验证码
req.getSession().removeAttribute(KAPTCHA_SESSION_KEY);
String code req.getParameter(code);
// 获取用户名
String username req.getParameter(username);
if (token ! null token.equalsIgnoreCase(code)) {
System.out.println(保存到数据库 username);
resp.sendRedirect(req.getContextPath() /ok.jsp);
} else {
System.out.println(请不要重复提交表单);
}
}切换验证码
// 给验证码的图片绑定单击事件
$(#code_img).click(function () {
// 在事件响应的 function 函数中有一个 this 对象。这个 this 对象是当前正在响应事件的 dom 对象
// src 属性表示验证码 img 标签的 图片路径。它可读可写
// alert(this.src);
//因为浏览器缓存的问题所以后面都需要有一个不同的值。
this.src ${basePath}kaptcha.jpg?d new Date();
});3. kaptcha详细参数