spring aspectj小试2

/**
 * @author zhuc
 * @version 2012-8-21 下午1:38:39
 */
@Aspect
@Component
public class Aspect2 {

	/**
	 * @param joinPoint
	 * @param log
	 */
	@After(value = "@annotation(log)")
	public void doAfter(JoinPoint joinPoint, Log log) {
		for (Object obj : joinPoint.getArgs()) {
			System.out.println("参数: " + obj);
		}
		System.out.println(log.function() + "," + log.desc());
		System.out.println("doAfter......");
	}
}

 

/**
 * @author zhuc
 * @version 2012-8-21 下午1:42:07
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Log {
	String function() default "";
	String desc() default "";
}

 

/**
 * @author zhuc
 * 
 */
public class Service {

	/**
	 * @param name
	 * @return
	 */
	@Log(function = "日志管理", desc = "添加Log")
	public String addLog(String name) {
		System.out.println(name);
		return "hello:" + name;
	}
}

 

<?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:context="http://www.springframework.org/schema/context"
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd   
           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd   
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">
	
	<context:component-scan base-package="org.zhuc.maven.aspectj" />
	<aop:aspectj-autoproxy />
	
	<bean id="service" class="org.zhuc.maven.aspectj.Service" />

</beans>

 

 

/**
 * @author zhuc
 * @version 2012-8-21 下午1:45:19
 */
public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		ApplicationContext ac = new FileSystemXmlApplicationContext(
				"src/test/java/org/zhuc/maven/aspectj/aspectj.xml");
		Service s = (Service) ac.getBean("service");
		String str = s.addLog("zhuc");
		System.out.println(str);
	}

}

 

运行结果:

zhuc
参数: zhuc
日志管理,添加Log
doAfter......
hello:zhuc

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值