1.说明
系统拦截器的应用。
表单重复提交:当使用请求转化进行跳转的时候,存在着表单重复提交的问题。
2.在表单中加入s:token
如果页面加入了struts2的标签,页面的请求必须进入struts2的核心控制器。
s:token会被解析为隐藏域,隐藏域中的值是服务器产生的一个token,当提交表单的时候,会将token的值提交到服务器,struts2将客户端提交的token和session中的token比较:
如果匹配,正常提交,执行处理请求的方法
如果不匹配,返回值指定的result,result的名字为invalid.token
<form action="userAction_userReg.action" method="post">
<s:token></s:token>
<div>
<input name="uname" type="text" />
</div>
<div>
<input name="upwd" type="text" />
</div>
<div>
<input type="submit" />
</div>
</form>
3. 定义Action
public class UserAction extends ActionSupport
{
// org.apache.struts2.interceptor.TokenInterceptor
private String uname;
private String upwd;
public String getUname()
{
return uname;
}
public void setUname(String uname)
{
this.uname = uname;
}
public String getUpwd()
{
return upwd;
}
public void setUpwd(String upwd)
{
this.upwd = upwd;
}
public String userReg()
{
System.out.println(uname + "\t" + upwd);
return Action.SUCCESS;
}
}
4. 配置Action
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<package name="user" namespace="/" extends="struts-default">
<interceptors>
<!-- 自定义拦截器栈 -->
<interceptor-stack name="mystack">
<interceptor-ref name="token"></interceptor-ref>
<!-- 引入系统默认的拦截器 -->
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<action name="userAction_*" class="com.guangsoft.action.UserAction"
method="{1}">
<!-- 引用拦截器栈 -->
<interceptor-ref name="mystack"></interceptor-ref>
<result name="invalid.token">/index.jsp</result>
<result>/show.jsp</result>
</action>
</package>
</struts>
TokenSession:自己测试,不需要配置<result name="invalid.token">/index.jsp</result>
Invalid.token,默认在哪里刷新,停留在哪里。