Spring AOP 起步

(2008年01月13日) Published by [Technorati] Tag results for java
其实我的个人表达能力不是很好……估计小时候语文没学好~也可能是aop这个概念本身意会的程度很大吧!呵呵寒暄一下! 正式进入主题:AOP 即 Aspect Oriented Programming 的缩写,中文译为”面向切面编程”。本篇没那么学术化,只是为了快速入门了解真实的使用方式!我们不用那么早去想这个名词的意义,fellow me,用真实的代码透析AOP的含义。 不知各位有没有项目开发的经验,如果有的话你应该可以清楚地了解到我们的代码中常常充斥着大量的日志记录代码,我们用log4j等日志记录工具一段一段地记录程序运行的信息。也许有个别是十分特殊的,但是似乎大部分都是例行公事吧!或者在丢出exception的时候捕获其message然后记入日志对吗?这样的代码难道不觉得碍眼?修改起来是不是也很麻烦?要是我们换了一个日志记录工具怎么办?呵呵,别吓到了,没这么严重啦,这些都是极端情况,平时我们还是很开心地写着这些东西。但是今天要说到的这个aop可以将一些特别的操作提取出来,作为我们的”通知-advice”,在运行时加载到对象中。就是说,我们可以在代码中不写日志记录段,但是在运行时加
Read More ......
本站相关内容:

Spring AOP 起步

其实我的个人表达能力不是很好……估计小时候语文没学好~也可能是aop这个概念本身意会的程度很大吧!呵呵寒暄一下! 正式进入主题:AOP 即 Aspect Oriented Programming 的缩写,中文译为"面向切面编程"。本篇没那么学术化,只是为了快速入门了解真实的使用方式!我们不用那么早去想这个名词的意义,fellow me,用真实的代码透析AOP的含义。 不知各位有没有项目开发的经验,如果有的话你应该可以清楚地了解到我们的代码中常常充斥着大量的日志记录代码,我们用log4j等日志记录工具一段一段地记录程序运行的信息。也许有个别是十分特殊的,但是似乎大部分都是例行公事吧!或者在丢出exception的时候捕获其message然后记入日志对吗?这样的代码难道不觉得碍眼?修改起来是不是也很麻烦?要是我们换了一个日志记录工具怎么办?呵呵,别吓到了,没这么严重啦,这些都是极端情况,平时我们还是很开心地写着这些东西。但是今天要说到的这个aop可以将一些特别的操作提取出来,作为我们的"通知-advice",在运行时加载到对象中。就是说,我们可以在代码中不写日志记录段,但是

spring aop

在使用spring aop的时候碰到一个问题,在一个aop:config里面可以配多个切点表达式,在另外的aop:config里也是可以引用.配切面的时候,一个切面里面怎么不可以配多个通知,比如在记录日志的时候,有个logaspt类把它配置为切面,在这个切面里面配了一个前置的通知,是可以正常工作但是在配一个后置通知怎么就可以了,会出异常代码如下:

<!-- 日志aspectbean-->
  <bean id="loggerBean" class="cn.hxex.springhibernate.base.LoggerBean"/>

<!-- 声明aop -->
 <aop:config>                                        <!-- 声明事务切点 -->
   <aop:pointcut id="productServiceMethods"
     expression="execution(* cn.hxex.springhibernate.service..*.*(..))"/>
                                                      <!--声明日志切点 -->
     <aop:pointcut id="loggerCalls"
   expression="execution(* cn.hxex.springhibernate..*.*(..))"/>
  <aop:advisor advice-ref="txAdvice" pointcut-ref="productServiceMethods" />
    <aop:aspect id="logAspect" ref="loggerBean">      <!--声明日志切面-->
                                                      <!--声明通知  -->
         <aop:before pointcut-ref="loggerCalls" method="before"/>
       <aop:after-returning pointcut-ref="loggerCalls" method="after"/>

    </aop:aspect>

  </aop:config>

难道一个切面不可以声明多个通知吗?

如果一个切面里不可以声明如一个前置或一个环绕的是一个理解的,怎么不可以声明一个前置和一个后置的?不解



已有 0 人发表留言,猛击->> 这里<<-参与讨论


JavaEye推荐



Spring Aop

   这几天在看Spring Aop的东西,做了一个简单的小例子:

 

 

 

public interface IHello {
	
	public String hello(String name) ;

}

public class HelloSpeaker implements IHello {

	public String hello(String name) {
		
		String hello = " Hello " + name ;
		
		System.out.println( hello );
		
		return hello ;
	}

}

   上面的是接口和实现类,也就是需要被AOP处理的类,也就是Target.


    下面这个类,是AOP中Aspect,切入类,我采用的是,afterReturn类型
   
     
public class AfterReturnExample {
	
	public void profile( Object retVal ) {
		
		
		System.out.println(" the result " + retVal );
		
		System.out.println(" after return ");
		
	}

} 

下面是spring的配置文件:

<?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:p="http://www.springframework.org/schema/p"
	     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">
           
	
	<aop:config>
		<aop:aspect id="beforeExample" ref="afterReturnExample">
			<aop:after-returning pointcut="execution(* com.ultrapower.demo.aop.*.*(..))" method="profile" returning="retVal"/>
		</aop:aspect>
	</aop:config>
	
	<bean id="hello" class="com.ultrapower.demo.aop.HelloSpeaker"></bean>
	
	<bean id="afterReturnExample" class="com.ultrapower.demo.aop.before.AfterReturnExample"></bean>
	
</beans> 


下面是测试类:

public class Test {
	
	
	public static void main(String [] args) {
		
		ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("aop/applicationContext.xml");
		
		IHello hello = (IHello) context.getBean("hello");
		
		hello.hello("zzx") ;
		
	}
	

}



    刚刚开始的时候出现了一个错误:
- Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@1808199: defining beans 
[org.springframework.aop.config.internalAutoProxyCreator,org.springframework.aop.aspectj.AspectJPointcutAdvisor#0,hello,
afterReturnExample]; root of factory hierarchy
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.s
pringframework.aop.aspectj.AspectJPointcutAdvisor#0': Instantiation of bean failed; nested exception is org.springframew
ork.beans.BeanInstantiationException: Could not instantiate bean class [org.springframework.aop.aspectj.AspectJPointcutA
dvisor]: Constructor threw exception; nested exception is java.lang.IllegalArgumentException: warning no match for this 
type name: com.ultrapower.demo.aop [Xlint:invalidAbsoluteTypeName]


这个错误主要是 pointcut配置的错误,修改之后就可以了:pointcut="execution(* com.ultrapower.demo.aop.*.*(..))"
 


已有 0 人发表留言,猛击->> 这里<<-参与讨论


JavaEye推荐



AOP with Spring

dzone.com: java (35 reads)

In this article i present to you a simple tutorial on how to set up Spring AOP with minimal configuration. Spring AOP is a very powerful tool and the only runtime weaving implementation currently available.

Spring AOP Advice types

Before advice: Advice that executes before a join point, but which does not have the ability to prevent execution flow proceeding to the join point (unless it throws an exception). After returning advice: Advice to be executed after a join point completes normally: for example, if a method returns without throwing an exception
互联网相关内容: