struts2—拦截器
在Struts2中,如果用户没有指定执行哪些拦截器,struts2有一个默认执行的栈,defaultStack;
一旦如果用户有指定执行哪些拦截器,默认的拦截器栈就不会被执行
拦截器配置举例(struts-default.xml文件中,定义了struts提供的所有拦截器!)
//1. 定义拦截器以及拦截器栈
<interceptors>
1.1 拦截器定义
<interceptor name="" class="" />
1.2 拦截器栈的定义
<interceptor-stack name="defaultStack">
引用了上面拦截器(1.1)
</interceptor-stack>
</interceptors>
2. 默认执行的拦截器(栈)
<default-interceptor-ref name="defaultStack"/>
API
|-- Interceptor 拦截器接口
|-- AbstractInterceptor 拦截器默认实现的抽象类; 一般用户只需要继承此类即可继续拦截器开发
|-- ActionInvocation 拦截器的执行状态,调用下一个拦截器或Action
自定义一个拦截器案例
自定义拦截器必须实现com.opensymphony.xwork2.interceptor.Interceptor接口或继承AbstractInterceptor类,一般继承AbstractInterceptor类
首先创建一个HelloAction
package com.interceptor;
import com.opensymphony.xwork2.ActionSupport;
public class HelloAction extends ActionSupport{
public HelloAction() {
System.out.println("正在执行:HelloAction.HelloAction()");
}
private String name;
private String password;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String execute() throws Exception {
System.out.println("正在执行HelloAction.execute()");
if (name.equals("gqx") && password.equals("123")) {
return SUCCESS;
}else {
return INPUT;
}
}
}
继续创建一个拦截器HelloInterceptor类
package com.interceptor;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
public class HelloInterceptor extends AbstractInterceptor{
// 启动时候执行
@Override
public void init() {
System.out.println("创建了拦截器对象HelloInterceptor.init()");
}
// 拦截器业务处理方法
@Override
public String intercept(ActionInvocation arg0) throws Exception {
// TODO Auto-generated method stub
System.out.println("开始执行:HelloInterceptor.intercept()");
// 调用下一个拦截器或执行Action (相当于chain.doFilter(..)
// 获取的是: execute方法的返回值
String resultString=arg0.invoke();//在这里是去执行HelloAction了,所以返回的结果为success
System.out.println("HelloInterceptor.intercept()结束了"+resultString);
return resultString;
}
@Override
public void destroy() {
System.out.println("销毁....");
}
}
在同一个包下创建一个配置文件
<?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">
<!-- START SNIPPET: xworkSample -->
<struts>
<!-- 【拦截器配置】 -->
<package name="configinterceptor" namespace="/" extends="struts-default">
<interceptors>
<!-- 配置用户自定义的拦截器 -->
<interceptor name="helloInterceptor" class="com.interceptor.HelloInterceptor"></interceptor>
<!-- 自定义一个栈: 要引用默认栈、自定义的拦截器 -->
<interceptor-stack name="helloStack">
<!-- 引用默认栈 (一定要放到第一行)-->
<interceptor-ref name="defaultStack"></interceptor-ref>
<!-- 引用自定义拦截器 -->
<interceptor-ref name="helloInterceptor"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 【执行拦截器】 -->
<default-interceptor-ref name="helloStack"></default-interceptor-ref>
<action name="test" class="com.interceptor.HelloAction">
<result name="success">/f/success.jsp</result>
<result name="input">/f/error.jsp</result>
</action>
</package>
</struts>
<!-- END SNIPPET: xworkSample -->
以上的拦截器是全局的,如果需要设置成一个只针对单个的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">
<!-- START SNIPPET: xworkSample -->
<struts>
<package name="configinterceptor" namespace="/" extends="struts-default">
<interceptors>
<!-- 配置用户自定义的拦截器 -->
<interceptor name="helloInterceptor" class="com.interceptor.HelloInterceptor"></interceptor>
</interceptors>
<action name="test" class="com.interceptor.HelloAction">
<result name="success">/f/success.jsp</result>
<result name="input">/f/error.jsp</result>
<!-- 先执行默认栈中的拦截器 -->
<interceptor-ref name="defaultStack"></interceptor-ref>
<interceptor-ref name="helloInterceptor"></interceptor-ref>
</action>
</package>
</struts>
<!-- END SNIPPET: xworkSample -->
然后在struts.xml中去引用他即可。
最后一个就是他的register.jsp页面
<form action="${pageContext.request.contextPath }/test">
姓名<input type="text" name="name" />
密码<input type="text" name="password" />
<input type="submit"/>
</form>
启动服务器可以看见以下信息

继续在register.jsp页面去访问提交信息后可以看到控制台的信息

根据这个结果可以判断拦截器执行流程如下:

服务器启动:
创建所有拦截器、执行init()
访问:
先创建Action实例;
在执行拦截器,
最后拦截器放行,执行execute;返回success字符串。
拦截器案例:
只允许登入后的用户尅访问action,否则直接使用action会调回到登入页面。
代码太多了
js小练习:商品计算功能
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>商品计算</title>
<link rel="stylesheet" href="">
</head>
<script type="text/javascript">
window.onload = function() {
//获取元素
var oList = document.getElementById('list');
var aLi = oList.getElementsByTagName('li');
var oDiv = document.getElementById('div1');
var aInput = oDiv.getElementsByTagName('input');
//时间操作
for (var i = aLi.length - 1; i >= 0; i--) {
calculate(aLi[i]);
}
//封装函数
function calculate(li) {
var oInput = li.getElementsByTagName('input');
var oSpan = li.getElementsByTagName('span')[0];
var oEm = li.getElementsByTagName('em')[0];
oInput[0].onclick = function() {
if (parseInt(oSpan) > 0) {
oSpan.innerHTML = parseInt(oSpan.innerHTML) - 1 + '件';
oInput[2].value = parseInt(oSpan.innerHTML) * parseInt(oEm.innerHTML) + "元";
}
conAll();
allMoney();
}
oInput[1].onclick = function() {
oSpan.innerHTML = parseInt(oSpan.innerHTML) + 1 + '件';
oInput[2].value = parseInt(oSpan.innerHTML) * parseInt(oEm.innerHTML) + "元";
conAll();
allMoney();
}
}
//计算件数
function conAll() {
var result = 0;
for (var i = aLi.length - 1; i >= 0; i--) {
//获取一件商品的数量
var span = aLi[i].getElementsByTagName('span')[0];
result += parseInt(span.innerHTML);
}
//显示结果
aInput[1].value = result + '件';
}
//金额总计
function allMoney() {
var result = 0;
for (var i = aLi.length - 1; i >= 0; i--) {
var input = aLi[i].getElementsByTagName('input')[2];
if (input.value) {
result += parseInt(input.value);
}
}
aInput[3].value = result + '元';
}
}
</script>
<body>
<ul id="list">
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>4.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
<li>
<input type="button" value="-" />
<span>0件</span>
<input type="button" value="+" />
<em>1.00元</em> 结果:
<input type="text" />
</li>
</ul>
<div id="div1">
<input type="button" value="商品总计" id="btn1" />
<input type="text" id="number" />
<input type="button" value="价格总计:" id="btn2" />
<input type="text" id="price" />
</div>
</body>
</html>
struts2—拦截器的更多相关文章
- Struts2 拦截器配置以及实现
@(Java ThirdParty)[Struts|Interceptor] Struts2 拦截器配置以及实现 Struts2的拦截器应用于Action,可以在执行Action的方法之前,之后或者两 ...
- struts2 拦截器
拦截器:对Action的访问.可以拦截到Action中某个方法.与过滤器不同,过滤器过滤的是请求.过滤JSP.html.但是拦截器不能拦截jsp.html的访问. Struts2 拦截器在访问某个 A ...
- Struts2拦截器的使用 (详解)
Struts2拦截器的使用 (详解) 如何使用struts2拦截器,或者自定义拦截器.特别注意,在使用拦截器的时候,在Action里面必须最后一定要引用struts2自带的拦截器缺省堆栈default ...
- struts2拦截器
一.自定义拦截器 struts2拦截器类似于servlet过滤器 首先定义一个拦截器这个拦截器实现了Interceptor接口: package cn.orlion.interceptor; impo ...
- Struts2拦截器模拟
前言: 接触Struts2已经有一段时间,Student核心内容就是通过拦截器对接Action,实现View层的控制跳转.本文根据自身理解对Struts2进行一个Java实例的模拟,方便大家理解! 示 ...
- Struts2拦截器初涉
Struts2拦截器初涉 正在练习struts,本例是从一个pdf上摘抄的例子,那本pdf都不知道叫什么名字,不过感觉很适合初学者. 在这里要实现一个简单的拦截器"GreetingInter ...
- 浅谈Struts2拦截器的原理与实现
拦截器与过滤器 拦截器是对调用的Action起作用,它提供了一种机制可以使开发者定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行.同时也是提供了 ...
- 基于SSH2框架Struts2拦截器的登录验证实现(转)
大象在这里假设你已经弄清楚了Struts2拦截器的基本概念,可以进入实际运用了.那么我们在之前的基础上只需要做下小小的改变,就可以使用Struts2的拦截器机制实现登录的验证. 修改数 ...
- struts2拦截器interceptor的三种配置方法
1.struts2拦截器interceptor的三种配置方法 方法1. 普通配置法 <struts> <package name="struts2" extend ...
- Struts2拦截器原理以及实例
一.Struts2拦截器定义 1. Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,拦截器是AOP的一种实现. 2. ...
随机推荐
- 敏捷开发系列之旅 第二站(走近XP极限编程)
http://blog.csdn.net/happylee6688/article/details/21551065 上篇文章,我们探讨了什么是敏捷开发,以及敏捷开发的方法学.在这篇文章中,我们将继续 ...
- HTTPConnection与HTTPClient的区别
HttpClient是个很不错的开源框架,封装了访问http的请求头,参数,内容体,响应等等.HttpURLConnection是java的标准类,什么都没封装,用起来太原始,不方便.比如重访问的自定 ...
- Java更新XML的四种常用方法简介
本文简要的讨论了Java语言编程中更新XML文档的四种常用方法,并且分析这四种方法的优劣.其次,本文还对如何控制Java程序输出的XML文档的格式做了展开论述. JAXP是Java API for X ...
- Android开发之全局获取Context的技巧
转自<第一行代码-Android>进阶篇 这本书对于入门来说确实很棒,很简单明了的介绍了Android开发中涉及到的方方面面,对我的帮助很大,同时记录一些该书中一些对我以后开发有用的东西, ...
- 十个免费的Web压力测试工具
两天,jnj在本站发布了<如何在低速率网络中测试 Web 应用>,那是测试网络不好的情况.而下面是十个免费的可以用来进行Web的负载/压力测试的工具,这样,你就可以知道你的服务器以及你的W ...
- Exel 利用模板导出方法
#region Exel导出方法 [MaxuniAuthAttribute(Roles = "sysroles")] public void OrderExport(string ...
- UVa 201 Squares
题意: 给出这样一个图,求一共有多少个大小不同或位置不同的正方形. 分析: 这种题一看就有思路,最开始的想法就是枚举正方形的位置,需要二重循环,枚举边长一重循环,判断是否为正方形又需要一重循环,复杂度 ...
- 嵌入式linux市场份额
来自华清远见2014年度的调查统计数据显示,在嵌入式产品研发的软件开发平台的选择上,嵌入式Linux以55%的市场份额遥遥领先于其他嵌入式开发软件发平台,比去年增长了13个百分比,这已经是连续4年比例 ...
- Zepto picLazyLoad Plugin,图片懒加载的Zepto插件
嗯,学着国外人起名字Zepto picLazyLoad Plugin确实看起来高大上,其实js代码没几句,而且我每次写js都捉襟见肘,泪奔--- 图片懒加载有很多js插件,非常著名的属jQuery的L ...
- 【转】android的消息处理机制(图+源码分析)——Looper,Handler,Message
原文地址:http://www.cnblogs.com/codingmyworld/archive/2011/09/12/2174255.html#!comments 作为一个大三的预备程序员,我学习 ...