struts2内置拦截器和自定义拦截器详解(附源码)

一、Struts2内置拦截器

Struts2中内置类许多的拦截器,它们提供了许多Struts2的核心功能和可选的高级特 性。这些内置的拦截器在struts-default.xml中配置。只有配置了拦截器,拦截器才可以正常的工作和运行。Struts 2已经为您提供丰富多样的,功能齐全的拦截器实现。大家可以至struts2的jar包内的struts-default.xml查看关于默认的拦截器与 拦截器链的配置。内置拦截器虽然在struts2中都定义了,但是并不是都起作用的。因为并不是所有拦截器都被加到默认拦截器栈里了,只有被添加到默认拦 截器栈里的拦截器才起作用,看一下被加到默认拦截器栈的拦截器都有那些:
五.开发自定义的拦截器步骤

虽然,Struts
2为我们提供如此丰富的拦截器实现,但是在某种情况下并不能满足我们的需求,比如:访问控制的时候,在用户每次访问某个action时,我们要去校验用户
是否已经登入,如果没有登入我们将在action执行之前就被拦截,此时我们就需要自定义拦截器;下面我们具体看一下,如何实现自定义拦截器。

1.实现拦截器类

所有的Struts
2的拦截器都直接或间接实现接口com.opensymphony.xwork2.interceptor.Interceptor。
该接口提供了三

个方法:

1)    
void
init();在该拦截器被初始化之后,在该拦截器执行拦截之前,系统回调该方法。对于每个拦截器而言,此方法只执行一次。

2)    
void destroy();该方法跟init()方法对应。在拦截器实例被销毁之前,系统将回调该方法。

3)    
String intercept(ActionInvocation invocation) throws
Exception;该方法是用户需要实现的拦截动作。该方法会返回一个字符串作为逻辑视图。

除此之外,继承类com.opensymphony.xwork2.interceptor.AbstractInterceptor是更简单的一种实现拦截器类的方式,
为此类提供了init()和destroy()方法的空实现,这样我们只需要实现intercept方法。还有一种实现拦截器的方法是继承
MethodFilterInterceptor类,实现这个类可以实现局部拦截,即可以实现指定拦截某一个action的哪个方法,或者不拦截哪个方法

2.注册自定义拦截器

自定义拦截器类实现了,现在就要在struts.xml里注册这个拦截器;

1).注册拦截器,在struts.xml中的package节点下注册拦截器

<interceptors>

<!-- name:拦截器的名称,class:自定义拦截器的类
-->

<interceptorname="拦截器名称"class="自定义拦截器的class路径"/>

</interceptors>

2).使用拦截器,在需要使用自定义拦截器的action中定义如下代码

<action>

<interceptor-refname="拦截器名称"/>

</action>
注意:因为struts2的很多功能都是根据Struts2默认拦截器栈实现的;如果此处只使用自定义的拦截器时,将失去struts2的很多核心功能;所以需要定义一个拦截器栈(由一个或多个拦截器组成)即此拦截器栈中一定要包括<interceptor-ref
name="defaultStack"/>!!!!即如下:

3) 
拦截器栈
<interceptor-stack
name="拦截器栈的名称">

<!--需要注意的是:系统默认的拦截器栈应要放在前面,在加入自定义拦截器;
-->

<interceptor-ref
name="defaultState"/>

<interceptor-ref
name="自定义拦截器的名称"/>
</interceptor-stack>
4)  在action中使用栈
<action>

<interceptor-refname="栈名称或拦截器名称"/>

。。。。。

</action>
5)
如果此时需要所有的action都使用自定义拦截器或者拦截器栈时,此时就定义一个默认的拦截器或者拦截器栈,即全局的拦截器。

在<default-interceptor-ref
name="permissionStack"/>

注意:如果在某个action中又使用了另一个拦截器,此时默认的拦截器将失效,为了确保能够使用默认的拦截器(包含Struts2的默认拦截器),又需要添加其他拦截器时,可以在action中加上其他拦截器

下面咱就以继承MethodFilterInterceptor类(它是AbstractInterceptor的子类)来实现一个权限控制的拦截器,别的页面都不展示了,在此,展示出拦截器类和struts.xml的配置:

拦截器类AuthorInterceptor:

package com.bzu.intecepter;

import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.apache.struts2.StrutsStatics;

import com.opensymphony.xwork2.ActionContext;

import com.opensymphony.xwork2.ActionInvocation;

import
com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;

public class AuthorInterceptor extends MethodFilterInterceptor
{

@Override

protected String doIntercept(ActionInvocation invocation) throws
Exception {

// TODO Auto-generated method stub

ActionContext context = invocation.getInvocationContext();

// 通过ActionContext来获取httpRequest

HttpServletRequest request = (HttpServletRequest) context

.get(StrutsStatics.HTTP_REQUEST);

// 也可以通过ServletActionContext来获取httpRequest

// HttpServletRequest request =
ServletActionContext.getRequest();

// 取得根目录的绝对路径

String currentURL = request.getRequestURI();

// 截取到访问的相对路径,可以通过这个和权限表比较来进行相应的权限控制

String targetURL = currentURL.substring(currentURL.indexOf("/",
1),

currentURL.length());

System.out.println(currentURL + ".............." +
targetURL);

// 通过ActionContext获取session的信息,以Map形式返回

Map session = context.getSession();

// 获取容器里面的username值,如果存在说明该用户已经登录,让他执行操作,如果未登录让他进行登录

String username = (String) session.get("username");

System.out.println(username+"username");

if (username != null) {

invocation.invoke();

}

return "login";
}
}

下面来看一下具体的struts.xml的配置:

<!DOCTYPE struts
PUBLIC

"-//Apache
Software Foundation//DTD Struts Configuration 2.0//EN"

"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
<constant name="struts.i18n.encoding" value="utf-8"
/>
<package name="struts2"
extends="struts-default">
<interceptors>

<!-- 配置未登录进行操作的拦截器 -->

<interceptor
name="loginInterceptor"
class="com.bzu.intecepter.AuthorInterceptor">

<param
name="excludeMethods">login</param>

</interceptor>

<!-- 重新封装一个默认的拦截器栈 -->

        
<interceptor-stack
name="myDefaultStack">

<interceptor-ref name="loginInterceptor"
/>

<interceptor-ref name="defaultStack"
/>

</interceptor-stack>

</interceptors>

<!-- 为这个包设置默认的拦截器栈 -->

    
<default-interceptor-ref name="myDefaultStack"
/>

<global-results>

<result
name="login">/login.jsp</result>

</global-results>

<action name="LoginAction"
class="com.bzu.action.LoginAction" method="login"
>

<result
name="success">success.jsp</result>

<result
name="fail">fail.jsp</result>

<result
name="input">login.jsp</result>

</action>

</package>

</struts>

时间: 2024-07-30 13:52:54

struts2内置拦截器和自定义拦截器详解(附源码)的相关文章

SpringMVC拦截器详解[附带源码分析]

目录 前言 重要接口及类介绍 源码分析 拦截器的配置 编写自定义的拦截器 总结 前言 SpringMVC是目前主流的Web MVC框架之一. 如果有同学对它不熟悉,那么请参考它的入门blog:http://www.cnblogs.com/fangjian0423/p/springMVC-introduction.html 拦截器是每个Web框架必备的功能,也是个老生常谈的主题了. 本文将分析SpringMVC的拦截器功能是如何设计的,让读者了解该功能设计的原理. 重要接口及类介绍 1. Hand

Nginx内置变量以及日志格式变量参数详解

Nginx内置变量以及日志格式变量参数详解 $args #请求中的参数值 $query_string #同 $args $arg_NAME #GET请求中NAME的值 $is_args #如果请求中有参数,值为"?",否则为空字符串 $uri #请求中的当前URI(不带请求参数,参数位于$args),可以不同于浏览器传递的$request_uri的值,它可以通过内部重定向,或者使用index指令进行修改,$uri不包含主机名,如"/foo/bar.html". $d

[转]SpringMVC拦截器详解[附带源码分析]

目录 前言 重要接口及类介绍 源码分析 拦截器的配置 编写自定义的拦截器 总结 前言 SpringMVC是目前主流的Web MVC框架之一. 如果有同学对它不熟悉,那么请参考它的入门blog:http://www.cnblogs.com/fangjian0423/p/springMVC-introduction.html 拦截器是每个Web框架必备的功能,也是个老生常谈的主题了. 本文将分析SpringMVC的拦截器功能是如何设计的,让读者了解该功能设计的原理. 重要接口及类介绍 1. Hand

SpringBoot内置的各种Starter是怎样构建的?--SpringBoot源码(六)

注:该源码分析对应SpringBoot版本为2.1.0.RELEASE 1 温故而知新 本篇接 外部配置属性值是如何被绑定到XxxProperties类属性上的?--SpringBoot源码(五) 温故而知新,我们来简单回顾一下上篇的内容,上一篇我们分析了SpringBoot外部配置属性值是如何被绑定到XxxProperties类属性上的相关源码,现将外部属性绑定的重要步骤总结如下: 首先是@EnableConfigurationProperties注解import了EnableConfigur

Eclipse上搭建SSH(struts-2.2.3 + spring-2.5.6 + hibernate-3.6.8)框架-附源码

一直想自己搭建一个ssh框架,这次由于编写demo的需要,就亲手搭建了一下,并逐步测试!下面进入正题: 创建Struts项目 整合步骤: 1,在Eclipse中创建一个DynamicWeb Project,本文项目名称为SSH. 2,添加相应的jar包,放到SSH项目下的WEB-INF/lib下. 3,建立struts配置文件. 编写相应的测试代码: 1,在src目录下创建相应package. 2,在WebContent下创建Register.jsp文件,并分别创建注册成功和注册失败的Succe

2020了你还不会Java8新特性?(五)收集器比较器用法详解及源码剖析

收集器用法详解与多级分组和分区 为什么在collectors类中定义一个静态内部类? static class CollectorImpl<T, A, R> implements Collector<T, A, R> 设计上,本身就是一个辅助类,是一个工厂.作用是给开发者提供常见的收集器实现.提供的方法都是静态方法,可以直接调用. 函数式编程最大的特点:表示做什么,而不是如何做.开发者更注重如做什么,底层实现如何做. /** * Implementations of {@link

Android使用xml自定义软键盘效果(附源码)

Android使用xml自定义软键盘效果原理: 1,软键盘其实是个控件,使用android.inputmethodserver.KeyboardView类定义. 2,主布局中使用帧布局,当我们需要显示软键盘时设置为可见,不需要时设置为不可见. 3,编写xml文件,定义键盘内容.使用xml文件填充KeyBoardView布局 4,设置EditText的监听事件. 完成键盘开发. 上效果图: 1,源码研究android.inputmethodserver.KeyboardView: /* * Cop

SpringMVC拦截器详解[附带源码分析]作奏抓诅做准

http://www.ebay.com/cln/7vt_ldrz/2015.01.29/166953650015 http://www.ebay.com/cln/dtr_rfzf/2015.01.29/166836224013 http://www.ebay.com/cln/ldx_nxtv/2015.01.29/166688651010 http://www.ebay.com/cln/b1t_xbzd/2015.01.29/166688653010 http://www.ebay.com/cl

SpringMVC拦截器详解[附带源码分析]拽柞奏租卓咨

http://www.ebay.com/cln/tjp_btlh/2015.01.29/166584777017 http://www.ebay.com/cln/951_thpr/2015.01.29/166964286015 http://www.ebay.com/cln/r5d_nzjp/2015.01.29/166698555010 http://www.ebay.com/cln/lp5_bpxd/2015.01.29/166964288015 http://www.ebay.com/cl