AOP的简单实现

大家都知道在ssh组合的框架中spring扮演了一个极其重要的中间角色:既可以使用ioc解耦,也可以使用aop来对功用的方法进行重用。其实aop这种思想早就在j2se中就有体现了,是通过使用InvocationHandler接口和动态代理Proxy来实现的。废话不多说:下面就先上我写的一个小例子:

首先模仿spring写一个Logger类来模拟日志记录

Logger.class

package com.aopanalysis;

public class Logger {
	public static void logging(String level , String content){
		if(level.equals("log")){
			System.out.println("LOG:"+content+"(LOG ok)");
			
		}else if(level.equals("debug")){
			System.out.println("DEBUG:"+content+"(DEBUG ok)");
		}else {
			System.out.println("NO FOUND EQUALED CMD!");
		}
		
	}
}


然后是一个Hello.class和他的接口IHello.class

Hello.class

package com.aopanalysis;

public  class Hello implements IHello {
	String name;
	public Hello(String name){
		this.name = name;
	}
	@Override
	public void sayHello(String name) {
		// TODO Auto-generated method stub
		System.out.println("Hello "+name+"!");
	}

	@Override
	public void sayGoodbye(String name) {
		// TODO Auto-generated method stub
		System.out.println(name+"Goodbye "+"!");
	}

	

	

}

IHello.class

package com.aopanalysis;
public interface IHello {
	public void sayHello(String name);
	public void sayGoodbye(String name);
}

接下来就是重头戏了!实现InvocationHandler接口,实现invoke()方法,然后在自己写一个bind()方法,具体如下

DynamicProxyHandler.class

package com.aopanalysis;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class DynamicProxyHandler implements InvocationHandler {
	private Object delegate;
	@Override
	public Object invoke(Object proxy, Method method, Object[] args)
			throws Throwable {
		// TODO Auto-generated method stub
		Object result = null; 
		Logger.logging("debug", method.getName() + " Method end ."); 
		//JVM通过这条语句执行原来的方法(反射机制) 
		result = method.invoke(this.delegate, args);
		//执行原来的方法之后记录日志 
		Logger.logging("log", method.getName() + " Method Start!"); 
		return result;
	}
	public Object bind(Object delegate){
		this.delegate = delegate;
		return Proxy.newProxyInstance(this.delegate.getClass().getClassLoader(), this.delegate.getClass().getInterfaces(), this);
	}

}

经过上面几步,动态代理的aop基本就实现了。接下来用一个测试类来测试下:

Test.class

package com.aopanalysis;

public class Test {
	public static void main(String[] args) {
		IHello test = (IHello) new DynamicProxyHandler().bind(new Hello("123"));
		test.sayHello("Morning");
		test.sayGoodbye("Night!");
	}
}

结果如下图:


怎么样?是不是跟spring很像? 希望有机会各位大神不吝赐教,也希望明天自己能面试成功!

攒rp!




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring AOP(Aspect-Oriented Programming,面向切面编程)是一种通过声明式编程的方式,将关注点分离出来,比如日志、事务管理等,这些关注点可以集中在一个或多个“切面”中,然后在运行时动态地应用到目标对象上。Spring AOP实现主要包括以下几个步骤: 1. 定义切面(Aspect):在Spring中,使用`@Aspect`注解标记一个类作为切面,这个类通常包含`@Before`、`@After`、`@Around`等通知注解来定义处理切入点(Pointcut)的行为。 2. 定义切点(Pointcut):使用`@Before`、`@AfterReturning`、`@AfterThrowing`等注解来标识哪些方法或代码块需要被织入切面。Pointcuts表达式的语法允许指定各种条件,如方法名、参数类型等。 3. 编写通知(Advice):通知是在切面中执行的实际操作,它会在切点匹配的方法执行前后或异常处理过程中执行。常见的通知有简单通知(直接执行某段代码)、环绕通知(包装并执行一段代码)等。 4. 配置代理(Proxy):Spring通过JDK动态代理或CGLIB字节码生成技术创建AOP代理对象,该对象包含了目标方法以及切面的通知。 5. 连接通知和目标对象:在Spring配置文件中,使用`@Autowired`或`@Bean`定义AOP切面,并将其装配到目标bean上,使得Spring能够自动处理切面的织入。 6. 运行时执行:应用程序运行时,当目标方法被调用时,代理会拦截并按照预定义的切面和通知规则执行相应的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值