Struts2之拦截器篇
拦截器是Struts2框架的核心和基础,Struts2绝大多数功能都是通过拦截器来完成的,当StrutsPrepareAndExecuteFilter拦截到用户请求后,大量拦截器会对该请求进行处理,然后才调用用户自定义的Action类中的方法进行处理请求,由此可见,拦截器是Struts2的核心所在。
Struts2框架内建了大量的拦截器,我们可以在struts-default.xml中进行查看:
那么这些内置拦截器的具体作用是什么呢?
alias |
实现在不同请求中相似参数别名的转换 |
autowiring |
这是个自动装配的拦截器,主要用于当Struts2和Spring整合时,Struts2可以使用自动装配的方式来访问Spring容器中的 Bean |
chain |
构建一个Action链,使当前Action可以访问前一个Action的属性,一般和<result type="chain" .../>一起使用 |
conversionError |
这是一个负责处理类型转换错误的拦截器,它负责将类型转换错误从ActionContext中取出,并转换成Action的FieldError错误 |
createSession |
该拦截器负责创建一个HttpSession对象,主要用于那些需要有HttpSession对象才能正常工作的拦截器中 |
debugging |
当使用Struts2的开发模式时,这个拦截器会提供更多的调试信息 |
execAndWait |
后台执行Action,负责将等待画面发送给用户 |
exception |
这个拦截器负责处理异常,它将异常映射为结果 |
fileUpload |
这个拦截器主要用于文件上传,它负责解析表单中文件域的内容 |
i18n |
这是支持国际化的拦截器,它负责把所选的语言、区域放入用户Session中 |
logger |
这是一个负责日志记录的拦截器,主要是输出Action的名字 |
model-driven |
这是一个用于模型驱动的拦截器,当某个Action类实现了ModelDriven接口时,它负责把getModel()方法的结果堆入ValueStack中 |
params |
这是最基本的一个拦截器,它负责解析HTTP请求中的参数,并将参数值设置成Action对应的属性值 |
prepare |
如果action实现了Preparable接口,将会调用该拦截器的prepare()方法。 |
scope |
这是范围转换拦截器,它可以将Action状态信息保存到HttpSession范围,或者保存到ServletContext范围内 |
servlet-config |
如果某个Action需要直接访问Servlet API,就是通过这个拦截器实现的。 |
roles |
这是一个JAAS(Java Authentication and Authorization Service,Java授权和认证服务)拦截器,只有当浏览者取得合适的授权后,才可以调用被该拦截器拦截的Action |
timer |
这个拦截器负责输出Action的执行时间,这个拦截器在分析该Action的性能瓶颈时比较有用。 |
token |
这个拦截器主要用于阻止重复提交,它检查传到Action中的token,从而防止多次提交。 |
token-session |
这个拦截器的作用与前一个基本类似,只是它把token保存在HttpSession中 |
validation |
通过执行在xxxAction-validation.xml中定义的校验器,从而完成数据校验 |
workflow |
这个拦截器负责调用Action类中的validate方法,如果校验失败,则返回input的逻辑视图 |
scoped-model-driven |
如果一个Action实现了一个ScopedModelDriven接口,该拦截器负责从指定生存范围中找出指定的Modol,并将通过setModel方法将该Model传给Action实例 |
接下来我们以token这一内置的拦截器为例来看看Struts2中拦截器的应用(token拦截器用来处理用户重复提交的页,以防止错误发生):
首先配置struts开发环境,上一篇:Struts2框架基础篇 中有介绍,这里不重复说。
写一个登录页:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>Login</title></head><body><s:form action="login" method="post"><s:token></s:token><s:textfield name="username" label="username"></s:textfield><s:password name="password" label="password"></s:password><s:submit value="login"></s:submit></s:form></body>
</html>
编写action:
import com.opensymphony.xwork2.ActionSupport;public class LoginAction extends ActionSupport{private static final long serialVersionUID = 7222063566979612268L;private String username;private String password;public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}@Overridepublic String execute() throws Exception {return SUCCESS;}}
接着在struts.xml中配置action及拦截器:
<?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>
<!-- 配置struts可以受理的请求扩展名 ,这是默认的-->
<constant name="struts.action.extension" value="action,,"></constant><package name = "hello" extends = "struts-default" namespace = "/"><action name="login" class="org.interceptor.LoginAction"><result>/success.jsp</result><result name="invalid.token">/error.jsp</result><interceptor-ref name="defaultStack"></interceptor-ref><!-- defaultStack 是系统默认的拦截器栈,会自动应用,这里手动配置的原因是当为一个action配置拦截器时,默认的拦截器就不起作用了,所以必须显示的配置这个拦截器栈 --><interceptor-ref name="token"></interceptor-ref></action></package>
</struts>
最后,为了测试,编写一个成功界面以及重复提交被拦截界面:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>welcome</title></head><body>欢迎<s:property value="username"/></body>
</html>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>wrong</title></head><body>请不要重复提交</body>
</html>
测试运行:
输入用户名密码:
点击login:
刷新或者返回再次点击login,此时的操作会被拦截器拦截:
这样,用内置拦截器比较容易的就解决了表单重复提交的问题。
Struts2之拦截器篇相关推荐
- struts2自定义拦截器并配置拦截器使其生效
首先编写一个struts2的拦截器,要继承 MethodFilterInterceptor 并获取其中的方法 package star.july.d_interceptor;import com.op ...
- (转)Struts2的拦截器
http://blog.csdn.net/yerenyuan_pku/article/details/68648101 Struts2的拦截器 拦截器的概述 拦截器,在AOP(Aspect-Orien ...
- Struts2【拦截器】就是这么简单
2019独角兽企业重金招聘Python工程师标准>>> 什么是拦截器 拦截器Interceptor.....拦截器是Struts的概念,它与过滤器是类似的...可以近似于看作是过滤器 ...
- 第九篇——Struts2的拦截器
拦截器: Struts2大多数核心功能都是通过拦截器实现的,每个拦截器完成某项功能: 拦截器方法在Action执行之前或之后执行. 工作原理: 拦截器的执行过程是一个递归的过程 action请求--& ...
- struts2 18拦截器详解(五)
I18nInterceptor 该拦截器处理defaultStack第四的位置,是用来方便国际化的,如果说我们的一个Web项目要支持国际化的话,通常的做法是给定一个下拉框列出所支持的语言,当用户选择了 ...
- Struts2自定义拦截器实例—登陆权限验证
版本:struts2.1.6 此实例实现功能:用户需要指定用户名登陆,登陆成功进入相应页面执行操作,否则返回到登陆页面进行登陆,当直接访问操作页面(登陆后才能访问的页面)时则不允许,须返回登陆页面. ...
- dwz ajax session超时跳转登录页(struts2自定义拦截器)
1.定义struts2拦截器(网上例子很多) 代码如下: package rt.intercepter;import java.util.Map;import javax.servlet.http.H ...
- Struts2 自定义拦截器(方法拦截器)
转自:http://05061107cm.iteye.com/blog/365504 struts2系统自带了很多拦截器,有时需要我们自己定义,一般有两种方式: 一.实现Interceptor接口 J ...
- struts2中拦截器的使用
拦截器的使用 实现AOP 转自http://www.cnblogs.com/fmricky/archive/2010/05/24/1742514.html 1.什么是拦截器(Interceptor) ...
最新文章
- Linux内核实验作业四
- cad2014卡顿的解决方法_升级iOS14.1后出现卡顿、闪退?这3种方法可以解决
- aix卸载java,AIX系统学习之--卸载软件错误
- 不可靠的信号、可靠信号
- Ubuntu12.10中安装ati显卡驱动amd driver 13.1
- java controller json_springMVC的controller层接收前端json数据
- linux一个vlan配置多个端口映射,Linux 设置 多ip,多vlan
- java 不能用 random,关于Java中Random的一些使用细节
- Java重写《C经典100题》 --08
- php考勤管理系统论文,基于PHP的高职院校学生考勤管理系统的研究
- matlab ignoreanalyticconstraints,MATLAB函数随笔之计算篇
- 2017计算机二级ms office高级应用成绩查询
- 边缘计算 | 在移动设备上部署深度学习模型的思路与注意点
- SQL SERVER数据库误删除误格式化误重装软件覆盖数据恢复修复
- performance API 中什么指标可以衡量首屏时间
- Excel中F4键的作用
- 游戏专辑一 3D游戏碰撞之体素内存、效率优化(未完待续10/14)
- 学习c#的最后一天,做了一个文字版的1V1的小游戏
- 阅读笔记 | Code to Comment “Translation”:Data, Metrics, Baselining Evaluation
- 【数据结构】树的逻辑结构
热门文章
- 卢伟冰直播拆机 或是性价比最高的骁龙855手机
- 情人节民宿预定量同比增200% 北京建国门最火
- 2019支付宝集五福高阶玩法 助你快速集齐五福
- 拳王虚拟项目公社:解除网站禁止复制的插件,Simple Allow Copy V 0.8.2
- 最有效的七大性能测试技术
- RTTI机制(运行时类型识别)
- java8 hashmap_Java8 中的 HashMap
- oracle12c正在检查环境变量,oracle11g安装客户端检查先决条件失败
- Linux系统无线网络抓包程序(分析手机WIFI MAC地址)
- 合并两个有序链表 java_合并两个有序链表