struts2中的拦截器

一  AOP思想: 面向切面编程的思想

  AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

  AOP 是一个概念,一个规范,本身并没有设定具体语言的实现,这实际上提供了非常广阔的发展的空间。AspectJ是AOP的一个很悠久的实现,它能够和 Java 配合起来使用。

  Aspect: Aspect 声明类似于 Java 中的类声明,在 Aspect 中会包含着一些 Pointcut 以及相应的 Advice。

  Joint point:表示在程序中明确定义的点,典型的包括方法调用,对类成员的访问以及异常处理程序块的执行等等,它自身还可以嵌套其它 joint point。

  Pointcut:表示一组 joint point,这些 joint point 或是通过逻辑关系组合起来,或是通过通配、正则表达式等方式集中起来,它定义了相应的 Advice 将要发生的地方。

  Advice:Advice 定义了在 pointcut 里面定义的程序点具体要做的操作,它通过 before、after 和 around 来区别是在每个 joint point 之前、之后还是代替执行的代码。

二  责任链模式

  责任链模式是一种设计模式。在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链。请求在这个链上传递,直到链上的某一个对象决定处理此请求。发出这个请求的客户端并不知道链上的哪一个对象最终处理这个请求,这使得系统可以在不影响客户端的情况下动态地重新组织和分配责任。

三  拦截器的基本概念

  在struts2中定义了一系列的拦截器, 在拦截器中帮我们实现了一些功能. 在struts2中定义了一些拦截器, 但并不是所有拦截器都会执行, 只会执行一些默认的拦截器. 拦截器的底层是基于AOP和责任链模式实现的

    <interceptor-stack name="defaultStack">
                <interceptor-ref name="exception"/>
                <interceptor-ref name="alias"/>
                <interceptor-ref name="servletConfig"/>
                <interceptor-ref name="i18n"/>
                <interceptor-ref name="prepare"/>
                <interceptor-ref name="chain"/>
                <interceptor-ref name="scopedModelDriven"/>
                <interceptor-ref name="modelDriven"/>
                <interceptor-ref name="fileUpload"/>
                <interceptor-ref name="checkbox"/>
                <interceptor-ref name="datetime"/>
                <interceptor-ref name="multiselect"/>
                <interceptor-ref name="staticParams"/>
                <interceptor-ref name="actionMappingParams"/>
                <interceptor-ref name="params"/>
                <interceptor-ref name="conversionError"/>
                <interceptor-ref name="validation">
                    <param name="excludeMethods">input,back,cancel,browse</param>
                </interceptor-ref>
                <interceptor-ref name="workflow">
                    <param name="excludeMethods">input,back,cancel,browse</param>
                </interceptor-ref>
                <interceptor-ref name="debugging"/>
                <interceptor-ref name="deprecation"/>
            </interceptor-stack>

<default-interceptor-ref name="defaultStack"/>
        <default-class-ref class="com.opensymphony.xwork2.ActionSupport" />

  

拦截器的执行过程

(1)Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,拦截器是AOP的一种实现.

(2)在struts2里面执行默认的拦截器,在action不需要调用拦截器的方法,使用配置方式执行--- aop思想

(3)执行很多的拦截器,比如有三个拦截器,首先执行拦截器1,做放行,执行拦截器2,之后放行,执行拦截器3,放行之后,之后action里面的方法

  拦截器栈(Interceptor Stack)。Struts2拦截器栈就是将拦截器按一定的顺序联结成一条链。在访问被拦截的方法或字段时,Struts2拦截器链中的拦截器就会按其之前定义的顺序被调用。  

四  拦截器与过滤的区别

1、拦截器是基于Java的反射机制的,而过滤器是基于函数回调。

2、拦截器不依赖与servlet容器,过滤器依赖与servlet容器。

3、拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用,过滤jsp、过滤html、过滤图片路径、过滤servlet。

4、拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。

5、在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次

6、执行顺序 :过滤前 - 拦截前 - Action处理 - 拦截后 - 过滤后

五  自定义拦截器

(1)自定义拦截器实现

第一种创建类,继承AbstractInterceptor

第二种创建类,继承 MethodFilterInterceptor

(2)通过配置方式让action里面某个方法不进行拦截

(3)让action和拦截器类关联(通过配置完成)

实例: 自定义拦截器, 实现未登录的客户访问权限控制

1> 自定义拦截器, 继承MethodFilterInterceptor

package cn.rodge.interceptor;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;
import cn.rodge.entity.Users;
public class LoginInterceptor extends MethodFilterInterceptor {
    private static final long serialVersionUID = 1L;
    @Override
    protected String doIntercept(ActionInvocation invocation) throws Exception {
        //1.判断是否处于登陆状态
        Users user = (Users) ServletActionContext.getRequest().getSession().getAttribute("user");
        if (user != null) {
            //2.如果处于登陆状态,则放行
            return invocation.invoke();
        } else {
            //3.如果没有登陆,则返回到登陆界面
            return "login";
        }
    }
}
2> 在struts.xml中配置

<?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>
    <!-- 配置后缀名 -->
    <constant name="struts.action.extension" value="action,,"></constant>
    <package name="customeraction" extends="struts-default" namespace="/">
        <!-- 配置拦截器 -->
        <interceptors>
            <interceptor name="loginInterceptor" class="cn.rodge.interceptor.LoginInterceptor"></interceptor>
        </interceptors>
        
        <global-results>
            <result name="login">/login.jsp</result>
        </global-results>
    
        <action name="customer_*" class="cn.rodge.action.CustomerAction" method="{1}">
            <!-- 在action中声明自定义拦截器 -->
            <interceptor-ref name="loginInterceptor">
                <!-- 去除对登陆界面的拦截 -->
                <param name="excludeMethods"></param>
            </interceptor-ref>
            <!-- 引用默认拦截器 -->
            <interceptor-ref name="defaultStack"></interceptor-ref>
            
            <!-- 输入action地址,跳转到首页 -->
            <result name="ok">/index.jsp</result>
            <!-- 获取客户列表功能 -->
            <result name="list">/jsp/customer/list.jsp</result>
            <!-- 跳转到添加用户界面 -->
            <result name="addPage">/jsp/customer/add.jsp</result>
            <!-- 用户添加成功后跳转到成功界面 -->
            <result name="ok">/jsp/success.jsp</result>
        </action>
        
        <!-- 用户模块的action -->
        <action name="Users_*" class="cn.rodge.action.UsersAction" method="{1}">
            <!-- 登陆功能界面 -->
            <result name="loginSuccess">/index.jsp</result>           
        </action>
    </package>
</struts>

推荐链接:http://blog.csdn.net/kingmax54212008/article/details/51777851

时间: 2024-08-04 12:09:12

struts2中的拦截器的相关文章

好记性不如烂笔头49-javaWeb框架struts2中的拦截器(4)

1. Struts2的拦截器概述 Struts2拦截器是在访问某个Action或Action的某个方法之前拦截,或者在运行之后处理.Struts2拦截器是可插拔的,拦截器是AOP(Aspect Oriented Programming,面向切面编程)的一种实现 Struts2的拦截器栈(InterceptorStack)就是将拦截器按一定的顺序联结成一条链.在访问被拦截的方法或字段时,Struts2拦截器链中的拦截器就会按其之前定义的顺序被调用. Struts2规定用户自定义拦截器必须实现com

struts2 中 paramsPrepareParamsStack 拦截器

struts2二次参数拦截器内容: 规定了请求的执行顺序 在struts2中,其拦截器为框架精华部分,而二次参数拦截器paramsPrepareParamsStack  对于解决数据回显,对象修改属性丢失的问题悠着很良好的处理机制. 在 struts-default.xml 中的默认拦截器配置中有以下部分(可自行查找源码,通常为:struts-2.5.2\src\core\src\main\resources): <interceptor-stack name="paramsPrepare

Debug查看Struts2中ExceptionMappingInterceptor拦截器怎么把ExceptionHolder放入值栈中,以及理解拦截器的工作原理。。。

1.小案例代码: jsp界面: <body> <s:property value="exceptionStack"/><br> <s:property value="exception"/><br> <s:property value="exception.getMessage"/> <form action="product-details.action&q

struts2中的拦截器问题

大多数的web端项目都会用到"权限"这个东西,首先要明白权限是捆绑在角色上的,也就是对应关系,权限:角色=n:1. 既然需要有权限的地方,那么拦截器自然不可以缺少了. 1.拦截器的配置文件(struts.xml): <package name="manage" namespace="/" extends="default"> <!--管理员 --> <interceptors>       

Struts2中的拦截器详解

拦截器是什么 拦截器是一种可以在让用户在Action执行之前和Result执行之后进行一些功能处理的机制. 拦截器在action执行之前和result执行之后的顺序是相反的,可以看下图: 也就是说执行的顺序是:Interceptor1-Interceptor2-Interceptor3-Action-Result–Interceptor3--Interceptor2--Interceptor1 拦截器的优点 下边是书上总结的优点,贴几张图,还是比自己写来得快. 拦截器有什么 在我们使用Actio

关于struts2的自定义拦截器和struts2的详细流程

1.其实我们大家平常都会用struts2用的很多,但是有的时候我们并不是真正的了解struts2的运行机制,下面给大家分享一下struts2的运行流程.MVC框架 解释如下: 1.  所有请求被Struts2核心控制器StrutsPreparaedAndExecuteFilter拦截 2.根据ActionMapper提供的信息决定如何进行下一步 3.ActionMapper主要依赖Struts2的配置文件struts.xml 4.接下来为每个Action创建Action代理类ActionProx

(转)关于struts2的自定义拦截器和struts2的详细流程

转自 http://www.94cto.com/index/Article/content/id/63218.html.话说,写的真不错. 1.其实我们大家平常都会用struts2用的很多,但是有的时候我们并不是真正的了解struts2的运行机制,下面给大家分享一下struts2的运行流程.MVC框架 解释如下: 1. 所有请求被Struts2核心控制器StrutsPreparaedAndExecuteFilter拦截 2.根据ActionMapper提供的信息决定如何进行下一步 3.Actio

java struts2入门学习---拦截器学习

转发: https://www.cnblogs.com/amosli/p/3521872.html 一.拦截器,拦截器栈 1.拦截器的作用 拦截器本质上和servlet的过滤器是一样的.在struts2中,拦截器能够对Action前后进行拦截,拦截器是一个可插拨的,你可以选择使用拦截器,也可以卸载拦截器. 2.拦截器执行顺序 在struts.xml文件中,<intercepto-ref/>中先引用的先执行,后引用的后执行.如果某个拦截器出错或不允许通过,那么下一个拦截器是不允许执行的. 需要拦

struts2入门之拦截器

1.拦截器的执行时间:在action对象创建之后,在具体的方法执行之前: 2.拦截器底层实现原理:用到AOP思想和责任链模式:AOP:面向切面编程,通俗的讲就是当某个功能模块要增加某一项功能时,尽可能不去修改源代码而是通过其他的方式来达到相同的效果,比如通过配置文件等方式:责任链模式和过滤链模式有点相似,过滤链模式是指比如,一个请求由多个过滤器进行过滤,每个过滤器进行放行之后才能到下一个过滤器,最后实现目的:但是责任链模式,比如要执行多个操作,有添加,修改,删除三个操作,首先执行添加操作,添加操