#from-anti-duplication
项目介绍
from-anti-duplication是用于java web应用服务器端提供表单防重复提交拦截功能的框架。适用于以下三种场景:
场景一:在网络延迟的情况下让用户有时间点击多次submit按钮导致表单重复提交
场景二:表单提交后用户点击【刷新】按钮导致表单重复提交
场景三:用户提交表单后,点击浏览器的【后退】按钮回退到表单页面后进行再次提交
项目结构
结构图:
时序图
#from-anti-duplication使用帮助
项目默认依赖springmvc,redis,jsp,freemark
maven配置:
com.yun
from-anti-duplication-def-impl
1.0.0
applicationContext.xml的配置token存储器使用的redis连接池:
class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:host-name="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}"
p:pool-config-ref="poolConfig" />
spring-from.xml配置token验证器和存储器:
spring-mvc.xml配置token拦截器:
如果使用了freemark生成页面,则配置以下自定义freemark标签,用于生成表单的token隐藏域,
在spring-mvc.xml中添加freemark的token标签生成器配置:
0
UTF-8
UTF-8
zh_CN
true,false
yyyy-MM-dd HH:mm:ss
yyyy-MM-dd
HH:mm:ss
0.######
true
/ftl/pony/index.ftl as p,/ftl/spring.ftl as s
true
在freemark的模版文件中使用生成表单隐藏域
fromtest.html:
用户名:
密码:
如果使用jsp生成表单页面则配置以下自定义jsp标签,用于生成表单隐藏域
在WEB-INF/tld文件夹下添加form-tags.tld文件:
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd"
version="2.1">
JSTL 1.1 core library
JSTL core
1.1
form
/form-tags
tokentag
com.yun.main.tag.core.TokenTag
JSP
在jsp页面添加如下指令来使用from-tokenTag标签:
${sessionScope['SPRING_SECURITY_LAST_EXCEPTION'].message}
用户名:
class="login_input" />
密码:
size="20" class="login_input" />
webapp根目录结构:
webapp/
┗ common/
┗ js/
┗ comm/
formtool.js
jquery.form.js
jquery-1.11.3.js
┗ WEB-INF/
┗ jsp/
formtest-jsp.jsp
┗ views/
formtest.html
当使用ajax提交表单时要做token域的更新操作请使用formtool.js提供的ajaxform表单提交功能。该插件基于jquery-1.11.3.js,jquery.form.js开发:
在页面引入jquery-1.11.3.js,jquery.form.js,formtool.js三个js文件。
提交表单示例:
function subAjax() {
$("#ajaxForm").commonAjaxSubmit({
"success" : function(data) {
alert(data.resultMsg);
},
"error" : function() {
alert("error");
}
});
}
用户名:
密码:
size="20" class="login_input" />