`
太阳神喻
  • 浏览: 106581 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

AOP

阅读更多

spring要实现aop需要:aspectjweaver.jar , aspectjrt.jar , cglib-nodep.jar

实现注解:common-annotations.jar

用注解方式实现的切面类:

package com.fsj.aop;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

/**
 * @Aspect 定义为切面
 * @Component 自动扫描的组件,把此类交给spring管理
 *
 */
@Component @Aspect 
public class MyIntercepor {

	/**
	 * @Pointcut 定义为切入点,切入点的名称即为方法名(包含括号)
	 * execution(* com.fsj..*.*(..))说明:
	 * 第一个“*”表示所有返回值类型,
	 * fsj后面的两个点表示包含子包,
	 * 第二个“*”表示所有类,
	 * 第三个“*”表示所有方法
	 * 括号中的两点表示任意个参数任意参数类型
	 * 
	
	@Pointcut("execution(* com.fsj..*.*(..))")
	public void anyMethod()
	{		
	}
	 */
	
	
	/**
	 * 只拦截com.fsj.service.impl.PersonServiceBean中的所有方法
	 */
	@Pointcut("execution(* com.fsj.service.impl.PersonServiceBean.*(..))")
	public void anyMethod()
	{		
	}
	
	/**
	 * 定义前置通知
	 * 括号中为切入点的名称
	 */
	@Before("anyMethod()")
	public void doAccessCheck()
	{
		System.out.println("-------1.前置通知--------");
	}
	
	/**
	 * 定义后置通知
	 * 括号中为切入点的名称
	 */
	@AfterReturning("anyMethod()")
	public void doAfterReturning()
	{		
		System.out.println("-------5.后置通知--------");
	}
	
	/**
	 * 定义最终通知
	 * 括号中为切入点的名称
	 */
	@After("anyMethod()")
	public void doAfter()
	{
		System.out.println("-------3.最终通知--------");
	}
	
	/**
	 * 定义最终通知
	 * 括号中为切入点的名称
	 */
	@AfterThrowing("anyMethod()")
	public void doAfterThrowing()
	{
		//异常通知在最终通知后执行
		//有异常时不会执行后置通知,也不会有环绕后通知
		System.out.println("-------异常通知--------");
	}
	
	
	/**
	 * 定义环绕通知
	 * 括号中为切入点的名称
	 * 环绕通知特别适合做权限控制
	 */
	@Around("anyMethod()")
	public Object doAround(ProceedingJoinPoint pjp) throws Throwable
	{
		Object result = null;
		System.out.println("-------2.环绕前通知:进入方法--------");
		result = pjp.proceed();
		System.out.println("-------4.环绕后通知:退出方法--------");
		
		return result;
	}
	
}

 

 

配置文件是:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"
		xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
		xmlns:aop="http://www.springframework.org/schema/aop"
		xmlns:tx="http://www.springframework.org/schema/tx"
		xmlns:context="http://www.springframework.org/schema/context"
		xsi:schemaLocation="
			http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
			http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
			http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
			http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">

	<aop:aspectj-autoproxy /><!-- 启用aop -->
	<context:component-scan base-package="com.fsj" /><!-- 启用自动扫描和管理bean -->
	
	<!--
	<bean id="myIntercepor" class="com.fsj.aop.MyIntercepor"></bean>
	<aop:config>
		<aop:aspect id="asp" ref="myIntercepor">
			<aop:pointcut  id="mycut" expression="execution(* com.fsj.service.impl.PersonServiceBean.*(..))"/>
			<aop:before method="doAccessCheck" pointcut-ref="mycut" />
			<aop:after-returning method="doAfterReturning" pointcut-ref="mycut"/>
			<aop:after-throwing method="doAfterThrowing" pointcut-ref="mycut" />
			<aop:after method="doAfter" pointcut-ref="mycut" />
			<aop:around method="doAround" pointcut-ref="mycut" />
		</aop:aspect>
	</aop:config>
	
	xml形式做aop
	-->


</beans>

 

 

 

还可以得到拦截的参数和返回值:

	/**
		 * 只拦截com.fsj.dao.impl.PersonDaoImpl中的所有方法
		 */
		@Pointcut("execution(* com.fsj.dao.impl.PersonDaoImpl.*(..))")
		public void anyMethod()
		{		
		}
		
		/**
		 * 拦截anyMethod()指定的方法并且要满足只有一个int类型的参数的方法
		 * 得到输入参数
		 * @param id
		 */
		@Before("anyMethod() && args(id)")
		public void doAccessCheck(int id)
		{
			System.out.println("-------前置通知--------" + id);
		}
		
		/**
		 *  拦截anyMethod()指定的方法
		 *  并且要满足只有一个String类型的参数和一个boolean类型的返回值的方法
		 * @param name 输入参数
		 * @param result 返回值
		 */
		@AfterReturning(pointcut="anyMethod() && args(name)",returning="result")
		public void doAfterReturning(String name,boolean result)
		{
			//有异常时不会执行后置通知
			System.out.println("-------后置通知--------name:"+name+"----------返回值:"+result);
		}
		
		@After("anyMethod()")
		public void doAfter()
		{
			System.out.println("-------最终通知--------");
		}
		
		/**
		 * 拦截异常并获得异常信息
		 * @param e
		 */
		@AfterThrowing(pointcut="anyMethod()",throwing="e")
		public void doAfterThrowing(Exception e)
		{
			System.out.println("-------异常通知--------"+e);
		}
		

 

或者把连接点作为参数传入通知:

@Aspect
public class TestAspect {
	@Pointcut("execution(* *(..))")
	private void pointCutMethod(){};
	
	@After("pointCutMethod()")
	// @After("execution(* *(String))")
	public void doAfter(JoinPoint jp) {   
        System.out.print("日志记录(方法执行后):\t"  
                + "类名:" + jp.getTarget().getClass().getName() + "方法名:"  
                + jp.getSignature().getName() + "\t");
        Object[] args = jp.getArgs();
        System.out.print("参数:" );
        for(Object obj : args){
        	System.out.print(" " + obj + " ");
        }
        System.out.println();
    }   
  
	@Around("execution(* *(..))")
    public Object doAround(ProceedingJoinPoint pjp) throws Throwable {   
        long time = System.currentTimeMillis();   
        Object retVal = pjp.proceed();   
        time = System.currentTimeMillis() - time;   
        System.out.println("方法执行时间: " + time + " ms");   
        return retVal;   
    }   
  
	@Before("execution(* *(..))")
    public void doBefore(JoinPoint jp) {   
        System.out.println("日志记录(方法执行之前): "  
                + jp.getTarget().getClass().getName() + "."  
                + jp.getSignature().getName());   
    }   
  
	@AfterThrowing(pointcut="pointCutMethod()" , throwing="e")
    public void doThrowing(JoinPoint jp, Throwable e) {   
        System.out.println("method " + jp.getTarget().getClass().getName()   
                + "." + jp.getSignature().getName() + " throw exception");   
        System.out.println(e.getMessage());  
        this.sendEx(e.getMessage());
    }   
  
    private void sendEx(String ex) {   
        //TODO 发送短信或邮件提醒  
    	if(ex != null)
    		System.out.println("向管理员发送警告");
    }   

 

分享到:
评论

相关推荐

    spring-aop.jar各个版本

    spring-aop-1.1.1.jar spring-aop-1.2.6.jar spring-aop-1.2.9.jar spring-aop-2.0.2.jar spring-aop-2.0.6.jar spring-aop-2.0.7.jar spring-aop-2.0.8.jar spring-aop-2.0.jar spring-aop-2.5.1.jar spring-aop-...

    aop所依赖的所有包

    AOP(Aspect-Oriented Programming,面向切面编程)是一种编程范式,旨在减少代码的重复性和增强可维护性,特别是在处理系统中的横切关注点时。这些关注点,如日志、事务管理、安全检查等,往往分散在系统的各个部分...

    aopalliance-1.0.jar及aopalliance源码

    **AOP Alliance简介** AOP Alliance是一个开源项目,它的全称是Aspect Oriented Programming(面向切面编程)Alliance,是Java平台上的一个接口集合,为面向切面编程的实现提供了一个统一的API。这个库的主要目的是...

    反射实现 AOP 动态代理模式(Spring AOP 的实现原理)

    面向切面编程(AOP)是一种编程范式,旨在将横切关注点(如日志、安全等)与业务逻辑分离,从而提高模块化。AOP通过预定义的“切面”对横切关注点进行模块化,从而可以在不修改业务逻辑代码的情况下增加新功能。动态...

    spring aop jar 包

    Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的重要组成部分,它提供了一种在不修改源代码的情况下,对程序进行功能增强的技术。这个"spring aop jar 包"包含了实现这一功能所需的类和接口,...

    aopalliance最新完整jar包

    在Java应用中,aopalliance.jar包扮演着至关重要的角色,它包含了一些核心接口,如`org.aopalliance.intercept.MethodInterceptor`和`org.aopalliance.aop.Advice`,这些接口定义了拦截器和通知的概念,它们是AOP的...

    spring-boot aop

    Spring Boot AOP(面向切面编程)是一种强大的设计模式,它允许我们在不修改现有代码的情况下,插入额外的功能或监控代码。在Spring框架中,AOP主要用于日志记录、事务管理、性能统计等场景。本示例是关于如何在...

    springAOP所依赖的jar包

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它允许程序员定义“切面”,这些切面可以封装跨越多个对象的行为或责任。在Java应用中实现AOP通常需要依赖于一些外部库,这些库在你提供的标题和描述中有所...

    aop开发环境jar包

    在IT行业中,AOP(Aspect-Oriented Programming,面向切面编程)是一种编程范式,它旨在提高软件的模块化程度,将关注点分离。在Java世界里,AOP常用于处理日志、事务管理、权限检查等横切关注点。当我们谈到“AOP...

    spring-aop-jar

    在IT领域,Spring框架是一个广泛使用的Java应用框架,它提供了许多功能,包括依赖注入、面向切面编程(AOP)等。"spring-aop-jar"这个主题涉及到Spring框架中的核心组件之一——Spring AOP。这里我们将深入探讨...

    开发工具 spring-aop-4.3.6.RELEASE

    开发工具 spring-aop-4.3.6.RELEASE开发工具 spring-aop-4.3.6.RELEASE开发工具 spring-aop-4.3.6.RELEASE开发工具 spring-aop-4.3.6.RELEASE开发工具 spring-aop-4.3.6.RELEASE开发工具 spring-aop-4.3.6.RELEASE...

    spring aop spring aop

    在给出的XML配置中,`&lt;aop:config&gt;`元素开启AOP支持,而`&lt;aop:aspect&gt;`元素用于定义切面,其内部通过`&lt;aop:pointcut&gt;`定义切点,并通过`&lt;aop:before&gt;`和`&lt;aop:after&gt;`指定通知。 为了使用这些配置,我们需要在代码...

    C#版本AOP注入

    在IT行业中,面向切面编程(Aspect-Oriented Programming,简称AOP)是一种设计模式,它旨在提高软件的模块化程度,将关注点分离,使业务逻辑与系统服务(如日志、事务管理、安全控制等)解耦。C#作为.NET框架的主要...

    利用C#实现AOP常见的几种方法详解

    面向切面编程(AOP,Aspect Oriented Programming)是一种编程范式,旨在通过将关注点分离,使得系统设计更加模块化。AOP的核心思想是将应用程序的横切关注点(如日志、事务管理、安全检查等)从核心业务逻辑中解耦...

    springAop与spring定时器

    Spring AOP(面向切面编程)是Spring框架中的一个重要组件,它允许我们在不修改源代码的情况下,通过在程序运行时动态地将代码插入到方法调用中,来实现跨切面的关注点,如日志记录、性能监控、事务管理等。...

    C# .net Aop 动态截获异常

    在.NET开发环境中,C#语言提供了丰富的特性(Attributes)、依赖注入(DI)和面向切面编程(AOP)等机制,使得我们可以构建更加灵活、可维护的代码。本主题将深入探讨如何使用C#和AOP来动态截获异常,以实现更高级别...

    Spring使用AOP的三个jar包

    最后,`aopalliance-1.0.0.jar`是AOP联盟提供的一个接口库,它定义了一些通用的AOP接口,比如`org.aopalliance.intercept.MethodInterceptor`和`org.aopalliance.intercept.MethodInvocation`,使得不同的AOP框架...

    aop@work.rar

    《面向切面编程(AOP)的工作原理与实践》 面向切面编程(Aspect-Oriented Programming,简称AOP)是软件开发中的一个重要概念,它旨在解决程序中的横切关注点,即那些跨越多个模块、类或方法的共同功能,如日志、...

    aopalliance-1.0.jar下载

    《aopalliance-1.0.jar:AOP联盟的核心库解析》 在Java开发领域,面向切面编程(Aspect-Oriented Programming, AOP)是一种重要的编程范式,它旨在将关注点分离,使系统设计更为模块化,降低耦合度。而aopalliance-...

    Spring中的AOP不生效

    ### Spring中的AOP不生效的原因及解决方法 在Java开发中,面向切面编程(Aspect Oriented Programming,简称AOP)是一种重要的编程思想和技术手段,主要用于处理横切关注点问题,如日志记录、性能统计、安全控制、...

Global site tag (gtag.js) - Google Analytics