引言:
拦截器(Interceptor)——通过代理的方式来调用,下面小编为大家介绍简单的struts2拦截器。
概述:
java的拦截器可以动态拦截Action调用的对象,它提供了一种机制,开发人员可以定义一个action执行前后的业务逻辑方法,也可以在一个action执行前阻止其执行,同时也可以提取action中重用的部分。struts2拦截器的作用在于后台和前台页面显示的交互,其实也就是action和jsp的交互。
内容:
1 struts2拦截器分类:
(1)默认拦截器:<interceptor-ref name="defaultStack"></interceptor-ref> ,若struts2配置文件中没有自定义的拦截器,自动执行默认的拦截器
(2)自定义拦截器:
<interceptor name="myInterceptor" class="com.interceptor.MyInterceptor"></interceptor> <span style="color:windowtext;"><span style="font-family:Consolas;"> <span style="color:windowtext;"> </span></span></span>
由于默认的拦截器不能满足开发人所有的需求, 开发人员为了满足自己业务逻辑需求,也可以自定义拦截器。struts2作为框架,可扩展性不可或缺。
代码示例:1)sturts2配置文件代码:
<!-- 包装管理action,适应不同的业务 -->
<package name="testlogin" namespace="/" extends="struts-default">
<interceptors>
<!-- 自定义的拦截器 -->
<interceptor name="myInterceptor" class="com.interceptor.MyInterceptor"></interceptor>
</interceptors>
<action name="login" class="com.action.LoginAction">
<result name="success">/success.jsp</result>
<result name="error" type="redirect">/error.jsp</result>
<result name="checkError" >/checkSession.jsp</result>
<interceptor-ref name="myInterceptor"></interceptor-ref>
</action>
</package>
2)自定义拦截器方法类:
package com.interceptor;
import java.util.Map;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;
public class MyInterceptor implements Interceptor {
@Override
public void destroy() {
// TODO Auto-generated method stub
System.out.println("----destroy()-----");
}
@Override
public void init() {
// TODO Auto-generated method stub
System.out.println("----init()-----");
}
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
System.out.println("----intercept()----");
Map<String,Object> session = invocation.getInvocationContext().getSession();
if(session.get("username") != null){
return invocation.invoke();
}else
{
return "checkError";
}
}
}
3)JSP页面代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>登录页面</title>
</head>
<body>
<form action="login">
用户登录!<br>
用户名:<input name="user.username" type="text"><br>
密码:<input name="user.password" type="text"><br>
<input id="btnLogin" type="submit" value="登录"/>
</form>
</body>
</html>
4)实现效果:
(3)自定义拦截链:
一个自定义拦截链中可以有多个自定义的拦截器,同时你也可以控制多个拦截器的顺序,多个拦截器的集合就是拦截链,也称之为拦截栈。自定义拦截链的用法与拦截器的用法类似,故不多言。
定义实例:
<interceptor-stack name="defaultInterceptorStack">
<interceptor-ref name="myInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
2 实现原理:
自定义拦截器实现struts2提供的Interceptor接口,或者也可以继承struts2的AbstractInterceptor类,若继承拦截器类,那么自定义的拦截器只包含一个intercept的方法即可。
若继承了MethodFilterInterceptor,针对action类的方法进行拦截,适用于action中有多个执行方法,拦截特定方法,示例如下:
<interceptor-ref name="defaultStack">
<param name="fun1()"></param>
<param name="fun2()"></param>
</interceptor-ref>
3 拦截器与filter的对比:
(1)使用范围不同:filter基于Web容器,拦截器基于struts2,filter范围比拦截器大。
(2)执行原理不同:filter执行原理是回调函数;拦截器是java反射,反射html的标签。
(3)职责范围:filter比拦截器大很多,拦截器只能过滤请求,filter不仅仅是过滤请求,还可以进行权限控制等职责;filter是细粒度,拦截器是粗粒度。
总结:
虽然,理论上知道了filter和拦截器的区别,但是原理的具体实践上,自己并不是很理解,还需要在实践中提高,拦截器的反射怎么实现的?filter的回调函数怎么实现?俩者之间的区别和联系?因此还有很多问题等着小编去探索,希望读者能留下宝贵的痕迹,帮助小编提高。