现在想起来这个问题还是挺恶心的,为了不让大家再有同样的痛苦,故写成BLOG来分享。
首先介意大家能用AJAX提交就从项目开始用AJAX的方法提交。
当然我现在介绍的不是用AJAX方法,我就是用的普通struts2方法,现在看来非常简单,由以下几步组成:
一:在将要提交页面上加
<s:token />
它的作用是在每次生成页面生成一个唯一的信息令牌,也就是默认的拦截器能识别出来的;
二:在struts.xml中加:
<interceptors>
<interceptor name="authority" class="com.aircom.zzy.interceptor.AuthorityInterceptor"></interceptor>
<interceptor-stack name="mydefault">
<interceptor-ref name="token">
<param name="includeMethods">roleAdd,roleUpd,moduleAdd,moduleUpd,add,upd</param>
</interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="mydefault"></default-interceptor-ref>
其中红色部分就是我要拦截的方法,当然是新增与修改了。把它这样写就不用每个都配置一次了。
<action name="roleAdd" class="com.aircom.zzy.action.RoleAction" method="roleAdd">
<result name="success" type="chain">roleList</result>
<result name="invalid.token">/webadmin/pages/result.jsp?opt=roleList</result>
</action>
这是对每一个方法的配置,有的人写了一个重复提交的页面来作为唯一跳转,但我认为那是不友好的,所以我用了一个页面中转,我的页面新增完了就到了列表页面,因此刷新时我还让它跳回列表页面,下面是我的中转页面result.jsp:
<%@ page language="java" pageEncoding="utf-8"%>
<%
String opt = request.getParameter("opt") + ".action";
%>
<script type="text/javascript">
window.location.href = '<%=opt%>';
</script>
大家看见了吧,简单吧!这们定义方法拦截,不用在每个页面上都加<token />,只在需要的地方写需要的代码,大大减轻了我们的工作量和代码的复杂度,个人认为是可取的,如果大家有什么好的意见,可以贴出来,共同学习。