谈谈 Struts2 的拦截器
套话
理解
意义
实现原理
的方法。当中系统对于拦截器的调用,是通过ActionInvocation来实现的。
代码演示
Dog 接口
<span style="font-family:Microsoft YaHei;">public interface Dog {
// info 方法声明
public void info();
// run 方法声明
public void run();
}</span>
Dog 实现
<span style="font-family:Microsoft YaHei;">public class DogImpl implements Dog {
@Override
public void info() {
System.out.println("我是一仅仅小小狗");
}
@Override
public void run() {
System.out.println("我奔跑迅速");
}
}</span>
拦截器类
<span style="font-family:Microsoft YaHei;">public class DogIntercepter {
// 第一个拦截器方法
public void method1() {
System.out.println("********** 通用模拟方法一 *********");
}
// 第二个拦截器方法
public void method2() {
System.out.println("********** 通用模拟方法二 *********");
}
}</span>
ProxyHandler 类
<span style="font-family:Microsoft YaHei;">public class ProxyHandler implements InvocationHandler {
// 需被代理的目标对象
private Object target;
// 创建拦截器实例
DogIntercepter di = new DogIntercepter();
// 运行代理的目标方法时,该invoke方法会被自己主动调用
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
Object result = null;
// 假设被调用方法的方法名为info
if ("info".equals(method.getName())) {
// 调用拦截器方法 1
di.method1();
result = method.invoke(target, args);
// 调用拦截器方法 2
di.method2();
} else {
result = method.invoke(target, args);
}
return result;
}
// 用于设置传入目标对象的方法
public void setTarget(Object target) {
this.target = target;
}
}</span>
代理工厂类
主程序
<span style="font-family:Microsoft YaHei;">public class TestDog {
/**
* @param args
*/
public static void main(String[] args) {
// 创建一个Dog实例,该实例将被作为代理的目标对象
Dog targetObject = new DogImpl();
Dog dog = null;
// 以目标对象创建代理
Object proxy = MyProxyFactory.getProxy(targetObject);
if (proxy instanceof Dog) {
dog = (Dog) proxy;
}
// 測试代理的方法
dog.info();
dog.run();
}
}</span>
效果图
结束语
的拦截器 就是基于 AOP 的思想实现的,仅仅只是,那会的 AOP 还没有提出比較明白的概念罢了。也能够说,拦截器就是 AOP 实现的前身。当然,兴许的 AOP 功能更强大一些。
谈谈 Struts2 的拦截器的更多相关文章
- 简单理解Struts2中拦截器与过滤器的区别及执行顺序
简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...
- struts2总结六: Struts2的拦截器
一.Struts2的系统结构图
- Struts2使用拦截器完成权限控制示例
http://aumy2008.iteye.com/blog/146952 Struts2使用拦截器完成权限控制示例 示例需求: 要求用户登录,且必须为指定用户名才可以查看系统中某个视图资源:否 ...
- Struts2自定义拦截器Interceptor以及拦截器登录实例
1.在Struts2自定义拦截器有三种方式: -->实现Interceptor接口 public class QLInterceptorAction implements Interceptor ...
- struts2之拦截器
1. 为什么需要拦截器 早期MVC框架将一些通用操作写死在核心控制器中,致使框架灵活性不足.可扩展性降低, Struts 2将核心功能放到多个拦截器中实现,拦截器可自由选择和组合,增强了灵活性,有利于 ...
- Struts2【拦截器】就是这么简单
什么是拦截器 拦截器Interceptor.....拦截器是Struts的概念,它与过滤器是类似的...可以近似于看作是过滤器 为什么我们要使用拦截器 前面在介绍Struts的时候已经讲解过了,Str ...
- 【struts2】拦截器基础
1)拦截器是什么? 拦截器(Interceptor)是Struts2最强大的特性之一,它是一种可以让你在Action执行之前和Result执行之后进行一些功能处理的机制.来回顾一下官方给出的Strut ...
- JavaWeb框架_Struts2_(三)---->Struts2的拦截器
2. Struts2的拦截器(使用拦截器实现权限控制) 2.1 拦截器的概述 拦截器是Struts2的核心组成部分,它可以动态的拦截Action调用的对象,类似与Servlet中的过滤器.Struts ...
- (转)Struts2的拦截器
http://blog.csdn.net/yerenyuan_pku/article/details/68648101 Struts2的拦截器 拦截器的概述 拦截器,在AOP(Aspect-Orien ...
随机推荐
- iOS - 设置导航栏之标题栏居中、标题栏的背景颜色
本章实现效果: Untitled.gif 前言: 项目中很多需求是要求自定义标题栏居中的,本人最近就遇到这中需求,如果用系统自带的titleView设置的话,不会居中,经过尝试,发现titleview ...
- UNIX 是什么?怎么诞生的?
要记住, 当一扇门在你面前关闭的时候, 另一扇门就会打开. 肯·汤普森(Ken Thompson) 和丹尼斯·里奇(Dennis Richie)两个人就是这句名言很好的实例.他们俩是20世纪最优秀的信 ...
- perl JSON模块使用
简介: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 它基于JavaScript(Standard ECMA-262 3rd Edition - De ...
- 紫书 例题 10-18 UVa 11346(连续概率)
就是面积计算,没什么好说的. #include<cstdio> #include<cmath> #define REP(i, a, b) for(int i = (a); i ...
- ADL & 实参相依的查找 & 成员与非成员的查找
也就是会根据实参,所处在的名字空间,来查找对应名字空间里面的函数. 对于<<也是常见的场景,会根据实际要打印出来的下一个操作数,来决定调用哪个命名空间里面的函数. 注意,不同命名空间里面的 ...
- berkeley db储存URL队列的简单实现增、删、查
Berkeley DB(BDB)是一个高效的嵌入式数据库编程库,C语言.C++.Java.Perl.Python.Tcl以及其它非常多语言都有其相应的API. Berkeley DB能够保存随意 ...
- 把握linux内核设计思想(三):下半部机制之软中断
[版权声明:尊重原创.转载请保留出处:blog.csdn.net/shallnet,文章仅供学习交流,请勿用于商业用途] 中断处理程序以异步方式执行,其会打断其它重要代码,其执行时该中 ...
- 设计模式之Flyweight模式(笔记)
享元模式:运用共享技术有效地支持大量细粒度的对象. 适用场合:假设一个应用程序适用了大量的对象.而大量的这些对象造成了非常大的存储开销时就应该考虑使用. 首先定义一个IFlyweight接口 publ ...
- 离散化求RECT1
本文转载至点击打开链接 #include<stdio.h> struct node{ int x1,y1,x2,y2,c; }; struct node s[1010]; int px[2 ...
- hadoop集群中动态添加新的DataNode节点
集群中现有的计算能力不足,须要另外加入新的节点时,使用例如以下方法就能动态添加新的节点: 1.在新的节点上安装hadoop程序,一定要控制好版本号,能够从集群上其它机器cp一份改动也行 2.把name ...