1.struts2能完成数据的设置,数据的封装,数据的类型转换,数据的校验等等。struts2是如何来完成这些功能的?struts2的所有功能都是由拦截器来完成的。

2.拦截器是struts2的核心。拦截器是一个类似于过滤器的类。在执行action的处理方法前会 先执行拦截器,然后再执行action的处理方法,然后再执行拦截器,再响应。

3. struts2的所有功能都是由拦截器来实现的,而拦截器在struts2中时可以自由配置和自由装配的。所以struts2的所有功能也都是可插拔的。并且struts2中的拦截器是可以自定义的,所以如果struts2没有提供项目所需的功能时,可以通过自定义拦截器来实现。

4. struts2的拦截器有哪些,分别有什么功能:

  • alias : 对于HTTP请求包含的参数设置别名
  • autowiring : 将某些JavaBean实例自动绑定到其他Bean对应的属性中。有点类似Spring的自动绑定,在Spring部分会详细说明
  • chain : 在Web项目开发中,以前使用Struts开发的时候经常碰到两个Action互相传递参数或属性的情况。该拦截器就是让前一个Action的参数可以在现有Action中使用。
  • conversionError : 从ActionContext中将转化类型时候发生的错误添加到Action的值域错误中,在检验的时候经常被使用来显示类型转化的错误信息
  • cookie : 从Struts2.0.7版本开始,可以把cookie注入Action中可设置的名字或值中
  • createSession : 自动创建一个HTTP的 Session, 尤其是对需要HTTP的Session的拦截器特别有用。比如下面介绍的TokenInterceptor
  • debugging : 用来对在视图间传递的数据进行调试
  • execAndWait : 不显示执行Action, 在视图上显示给用户的是一个正在等待的页面,但是Action其实是在背后正在执行着。该拦截器尤其在对进度条进行开发的时候特别有用。
  • exception : 将异常和Action返回的result相映射
  • fileUpload : 支持文件上传功能的拦截器
  • i18n : 支持国际化的拦截器
  • logger : 拥有日志功能的拦截器
  • modelDriven : Action执行该拦截器的时候,它可以从一个scope范围检索和存储model值,通过调用setModel方法去设置model的值
  • params : 将HTTP请求中包含的参数值设置到Action中
  • prepare : 假如Action继承了Preparable接口,则会调用prepare方法
  • staticParams : 对于在struts.xml文件中的Action中设置的参数设置到对应的Action中
  • scope : 在session或者application范围中设置Action的状态
  • servletConfig : 该拦截器提供访问包括HttpServletRequest和HttpServletResponse对象的Map方法
  • timer : 输出Action的执行时间
  • token : 避免重复提交的校验拦截器
  • tokenSession : 和token拦截器类似,但它还能存储提交的数据到session里
  • validation : 运行在action-validation.xml文件中定义的校验规则。(数据校验部分)
  • workflow : 在Action中调用validate检验方法。如果Action有错误则返回到 input 视图
  • store : 执行校验功能的时候,该拦截器提供存储和检索Action的所有错误和正确信息的功能
  • checkbox : 视图中如果有checkbox存在的情况,该拦截器自动将unchecked的checkbox当做一个参数(通常为false)记录下来。这样可以用一个隐藏的表单值来记录所有未提交的checkbox,而且缺省unchecked的checkbox值是布尔类型的,如果视图中checkbox的值设置的不是布尔类型,它就会被覆盖成布尔类型的值
  • profiling : 通过参数来激活或者不激活分析检测功能,前提示Web项目是在开发模式下。(涉及到调试和性能检验时使用)
  • roles : 进行权限配置的拦截器,如果登录用户拥有相应的权限才去执行某一特定的Action

5.struts2中拦截器定义的位置在struts-default.xml中

6.自定义拦截器步骤:

a) 编写类,实现Interceptor接口

public class ActionExecuteTimeInterceptor implements Interceptor{

    @Override
public void destroy() { } @Override
public void init() { } @Override
public String intercept(ActionInvocation invocation) throws Exception {
long start=System.currentTimeMillis();
//执行下一个拦截器 如果下面没有拦截器则执行action的处理方法,并将结果返回
String result = invocation.invoke();
System.out.println("执行时间为:"+(System.currentTimeMillis()-start));
return result;
} }

b) 在struts.xml中配置拦截器

<!-- 拦截器配置 -->
<interceptors>
<!-- 配置自定义拦截器
name 是唯一的
class 是自定义拦截器的完全限定名
-->
<interceptor name="executeTime" class="cn.sxt.interceptor.ActionExecuteTimeInterceptor"></interceptor>
</interceptors>

c) 在对应action中 引用自定义拦截器

<package name="default" extends="struts-default" namespace="/">
<!-- 拦截器配置 -->
<interceptors>
<!-- 配置自定义拦截器
name 是唯一的
class 是自定义拦截器的完全限定名
-->
<interceptor name="executeTime" class="cn.sxt.interceptor.ActionExecuteTimeInterceptor"></interceptor>
</interceptors>
<action name="add" class="cn.sxt.action.UserAction" method="add">
<result>/success.jsp</result>
<!-- 在action中引用自定义的拦截器 -->
<interceptor-ref name="executeTime"></interceptor-ref>
</action>
</package>

7.自定义拦截器有两种方式实现,一种实现Interceptor接口还可以继承AbstractInterceptor类来实现:如:

public class HelloInterceptor extends AbstractInterceptor{

    @Override
public String intercept(ActionInvocation invocation) throws Exception {
System.out.println("hello interceptor 被执行");
return invocation.invoke();
} }

8.如果引用了自定义拦截器,那么struts2的拦截器将不再起作用。如果需要使用struts2的拦截器需要手动引入。

<action name="add" class="cn.sxt.action.UserAction" method="add">
<result>/success.jsp</result>
<!-- 在action中引用自定义的拦截器 -->
<interceptor-ref name="executeTime"></interceptor-ref>
<interceptor-ref name="helloInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</action>

9.当自定义拦截器比较多时,在action中引用拦截器将会变得比较麻烦,所以呢,struts2提供了拦截器栈。拦截器栈是用来引用已经定义好的拦截器的。一个拦截器栈可以包括多个拦截器,引用拦截器栈的方式和引用拦截器的方式一样。

<!-- 拦截器配置 -->
<interceptors>
<!-- 配置自定义拦截器
name 是唯一的
class 是自定义拦截器的完全限定名
-->
<interceptor name="helloInterceptor" class="cn.sxt.interceptor.HelloInterceptor"></interceptor>
<interceptor name="executeTime" class="cn.sxt.interceptor.ActionExecuteTimeInterceptor"></interceptor>
<!-- 定义拦截器栈 -->
<interceptor-stack name="myStack">
<interceptor-ref name="executeTime"></interceptor-ref>
<interceptor-ref name="helloInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<action name="add" class="cn.sxt.action.UserAction" method="add">
<result>/success.jsp</result>
<!-- 在action中引用自定义的拦截器 -->
<interceptor-ref name="myStack"></interceptor-ref>
</action>

10.在struts2如果没有自定义拦截器时,action类会引用默认的拦截器栈。如果有自定义拦截器后,想自定义拦截器设置为默认拦截器应该如何操作?

在package中去定义一个default-interceptor-ref即可。

<!-- 设置默认拦截器 -->
<default-interceptor-ref name="myStack"></default-interceptor-ref>
<action name="add" class="cn.sxt.action.UserAction" method="add">
<result>/success.jsp</result>
</action>

11.拦截器的使用:

登录拦截器用来实现用户登录检查:

public class LoginInterceptor extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation invocation) throws Exception {
//判断执行的Action是否login.action
//如果不是 判断用户是否登录
//如果登录了 执行下一个拦截器,如果没有登录 去登录
//获取执行action的名称
String actionName=invocation.getProxy().getActionName();
if("login".equals(actionName)){
return invocation.invoke();
}
Object obj=ServletActionContext.getRequest().getSession().getAttribute("currentUser");
if(obj!=null){
return invocation.invoke();
}
return Action.LOGIN;
}
}

配置

<struts>
<package name="default" extends="struts-default" namespace="/">
<!-- 拦截器配置 -->
<interceptors>
<interceptor name="loginInterceptor" class="cn.sxt.interceptor.LoginInterceptor"></interceptor>
<interceptor-stack name="myStack">
<interceptor-ref name="loginInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="myStack"></default-interceptor-ref>
<!-- 定义全局结果集 -->
<global-results>
<result name="login">/login.jsp</result>
</global-results>
<action name="login" class="cn.sxt.action.UserAction" method="login">
<result>/success.jsp</result>
</action>
<action name="show" class="cn.sxt.action.UserAction" method="show">
<result>/show.jsp</result>
</action>
</package>
</struts>

12.总结:

拦截器是单列的,所有action执行的都是同一个拦截器。所以在自定义拦截器时要注意线程安全的问题。拦截器只拦截action。

13.注意过滤器和拦截器区别

14. 方法拦截器

方法拦截器是比拦截器更加细粒度的拦截器,只拦截方法。通过配置方法拦截器可以有效提高系统性能。

/**
* 自定义方法拦截器
*
*/
public class AddMethodInterceptor extends MethodFilterInterceptor{ @Override
protected String doIntercept(ActionInvocation invocation) throws Exception {
System.out.println("进入方法拦截器");
return invocation.invoke();
} }

配置

<!-- 配置方法拦截器 -->
<interceptor name="addInterceptor" class="cn.sxt.interceptor.AddMethodInterceptor">
<!-- 配置哪些方法 需要被拦截 -->
<param name="includeMethods">add</param>
<!-- 排除哪些方法不被拦截
<param name="excludeMethods"></param> -->
</interceptor>

java之struts2之拦截器的更多相关文章

  1. 简单理解Struts2中拦截器与过滤器的区别及执行顺序

    简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...

  2. Struts2使用拦截器完成权限控制示例

    http://aumy2008.iteye.com/blog/146952 Struts2使用拦截器完成权限控制示例 示例需求:    要求用户登录,且必须为指定用户名才可以查看系统中某个视图资源:否 ...

  3. Struts2【拦截器】就是这么简单

    什么是拦截器 拦截器Interceptor.....拦截器是Struts的概念,它与过滤器是类似的...可以近似于看作是过滤器 为什么我们要使用拦截器 前面在介绍Struts的时候已经讲解过了,Str ...

  4. Struts2学习-拦截器

    1.新建项目user4,建立好和user3一样的目录,与之相比只是添加几个类,主要是struts.xml和action类的改变,其结果没有太大的变化 struts,xml <?xml versi ...

  5. JavaWeb框架_Struts2_(三)---->Struts2的拦截器

    2. Struts2的拦截器(使用拦截器实现权限控制) 2.1 拦截器的概述 拦截器是Struts2的核心组成部分,它可以动态的拦截Action调用的对象,类似与Servlet中的过滤器.Struts ...

  6. 谈谈 Struts2 的拦截器

    套话 相信非常多人都用过 Struts2 了,当然,对 Struts2 的原理也都比較了解.之前在一个项目中就已经用到了,当初的理解也不过局限在应用的层面上,对于更深层次的原理.机制,了解的并非非常多 ...

  7. JavaWeb_(Struts2框架)拦截器interceptor

    此系列博文基于同一个项目已上传至github 传送门 JavaWeb_(Struts2框架)Struts创建Action的三种方式 传送门 JavaWeb_(Struts2框架)struts.xml核 ...

  8. Spring的AOP,Struts2的拦截器(Interceptor),以及springMVC的(interceptor)

    参考外链:http://www.ibm.com/developerworks/cn/java/j-lo-springaopfilter/ 1.首先,spring的AOP作用范围很广,可以使用Aspec ...

  9. struts2 paramsPrepareParamsStack拦截器简化代码(源码分析)

    目录 一.在讲 paramsPrepareParamsStack 之前,先看一个增删改查的例子. 1. Dao.java准备数据和提供增删改查 2. Employee.java 为model 3. E ...

随机推荐

  1. HTML试题解析

    1.关于CSS为什么会出现Bug说法不正确的是(). (选择二项) A:编写CSS样式时需要考虑在不同浏览器中实现表现一致 B:各大主流浏览器由于不同厂家开发,浏览器使用的内核不同,支持CSS的程度不 ...

  2. 重新学习Mysql数据13:Mysql主从复制,读写分离,分表分库策略与实践

    一.MySQL扩展具体的实现方式 随着业务规模的不断扩大,需要选择合适的方案去应对数据规模的增长,以应对逐渐增长的访问压力和数据量. 关于数据库的扩展主要包括:业务拆分.主从复制.读写分离.数据库分库 ...

  3. Spring Cloud Ribbon---微服务调用和客户端负载均衡

    前面分析了Eureka的使用,作为服务注册中心,Eureka 分为 Server 端和 Client 端,Client 端作为服务的提供者,将自己注册到 Server 端,Client端高可用的方式是 ...

  4. css3实现左侧固宽,右侧随着屏幕,右侧随着屏幕变化而变化

    A, ----float+calc(css3新属性计算属性)方式 <div class="Father"> <div class="LeftChildr ...

  5. PostgreSQL中的partition-wise aggregation

    partition-wise aggregation允许对每个分区分别执行的分区表进行分组或聚合.如果GROUP BY子句不包括分区键,则只能在每个分区的基础上执行部分聚合,并且必须稍后执行最终处理. ...

  6. 搭建EOS全节点并接入主网

    #EOS编译安装 #!/bin/bash #install.eos.sh #EOS 安装 #从github克隆主网代码 cd /opt git clone https://github.com/EOS ...

  7. 使用ffmpeg -re循环推流(循环读取视频文件)推送EasyDSS RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器的方法

    需求分析 众所周知,EasyDSS与EasyNVR最大的区别是,EasyDSS被动接受前端设备的推流,将推送过来的直播流进行直播转码.智能处理.视频分发,在通过CDN分发节点分发到终端播放SDK.而E ...

  8. [LeetCode] 45. Jump Game II 跳跃游戏 II

    Given an array of non-negative integers, you are initially positioned at the first index of the arra ...

  9. 当代码上传git时,提示Repository not found The requested repository does not exist, or you do not have permission to access it. fatal: Could not read from remote repository. Please make sure you have the corre

    1.检查当前git中设置的用户名与邮箱是否与自己电脑上的一致. 看这个文件中 如果不一致,只需要把里面的内容全部复制出来添加到git(看下图位置) 这是再执行:git push -u origin m ...

  10. VS Code 编译C++

    1.安装VS Code 2.安装插件 在左侧插件库 必须: c/c++ 插件 非必需: C++ Intellisense Include Autocomplete 3.安装编译调试环境mingw Mi ...