struts2——自定义拦截器
struts2拦截器是struts框架的核心功能之一。首先,struts框架所实现的自动数据填充功能就是利用拦截器来实现的。这里主要是来总结一下这段时间学习拦截的器的心得。
很明显拦截器所要做的工作是预处理或者后加工。框架本身所实现的参数填充就是在预处理阶段。类型转换中分别在预处理和后加工阶段进行,在预处理阶段把视图传来的字符串数据转化成相应的java数据类型,在业务处理完成后把结果类型再转化为字符串到达结果页面进行显示。
总结一下个人自定义拦截器的使用方法:
1.首先建立拦截器类来实现拦截器的逻辑功能。必须实现Interceptor接口
2.配置struts.xml来添加拦截器。
3.将拦截器与相应的动作联系在一起。
4.测试拦截器。
这里以我们最常用的身份验证来实现一个自定义的拦截器。
public class LimitInterceptor implements Interceptor {
/**
*
*/
private static final long serialVersionUID = 1L;
public void destroy() {
}
public void init() {
}
public String intercept(ActionInvocation invocation) throws Exception {
if (用户已登录) {
return invocation.invoke();
} else {
return "Log";
}
}
}
public class LimitInterceptor implements Interceptor {
/**
*
*/
private static final long serialVersionUID = 1L;
public void destroy() {
}
public void init() {
}
public String intercept(ActionInvocation invocation) throws Exception {
if (用户已登录) {
return invocation.invoke();
} else {
return "Log";
}
}
}
这里首先实现了拦截器类的逻辑功能,Interceptor接口中有三个方法destory、init、intercept三个方法。其中init和destory主要处理初始化和清理资源工作,这里不用进行实现。主要的业务逻辑都放在intercept中,这里主要的逻辑功能是检测用户是否登录,若登录了则invocation.invoke()表明继续执行,若未登录则转到一个公共的视图-Log,这是在struts.xml中声明的一个公共视图,也就是登录界面。
<interceptors>
<interceptor name="permission" class="interceptor.LimitInterceptor" />
<interceptor-stack name="permissionStack">
<interceptor-ref name="permission" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
<interceptors>
<interceptor name="permission" class="interceptor.LimitInterceptor" />
<interceptor-stack name="permissionStack">
<interceptor-ref name="permission" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>这里主要进行的是配置拦截器,在struts.xml中配置拦截器,就如同生命action相似。这里值得注意的是我们如果自定义了拦截器并且把它与某个动作相关联,那么系统的拦截器就会被默认屏蔽,则struts2的大部分核心工作都没法完成,所以我们的解决办法有两种,一是我们在为每个动作添加拦截器的时候同时添加上系统默认的拦截器;二是我们将系统拦截器与我们自己编写的拦截器一同包装成拦截器栈然后使用。这里我们使用第二种方式,因为这样便于修改和维护。
<action name="DeleteStudent" class="stumanage.action.DeleteStudent" method="execute">
<interceptor-ref name="permissionStack"/>
</action>
<action name="DeleteStudent" class="stumanage.action.DeleteStudent" method="execute">
<interceptor-ref name="permissionStack"/>
</action>这里有一个action为DeleteStudent,我们为这个动作添加拦截器,也就是如果你想进行删除学生的操作,你必须有权限,也就是必须登录了。
用<interceptor-ref name="permissionStack"/>这句话将我们封装的拦截器栈与此action联系在一起。这样我们自定义的拦截器就可以正常工作了。如果没有登录,你就没有删除学生的权限。
当然我们也可以使用
<default-interceptor-ref name="permissinStack"/>来使我们自定义的拦截器栈成为默认拦截器,也就是为每个action添加此拦截器栈。
作者 凌风