<?xml version="1.0" encoding="GBK"?> <project name="spring" basedir="." default=""> <property name="src" value="src"/> <property name="dest" value="classes"/> <path id="classpath"> <fileset dir="../../lib"> <include name="**/*.jar"/> </fileset> <pathelement path="${dest}"/> </path> <!-- 定义iajc task --> <taskdef resource= "org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties"> <classpath refid="classpath"/> </taskdef> <target name="compile" description="Compile all source code"> <delete dir="${dest}"/> <mkdir dir="${dest}"/> <copy todir="${dest}"> <fileset dir="${src}"> <exclude name="**/*.java"/> </fileset> </copy> <!-- 使用iajc编译包含AspecJ的Java程序 --> <iajc destdir="${dest}" debug="true" deprecation="false" failonerror="true"> <src path="${src}"/> <classpath refid="classpath"/> </iajc> </target> <target name="run" description="Run the main class" depends="compile"> <java classname="lee.AspectJTest" fork="yes" failonerror="true"> <classpath refid="classpath"/> </java> </target> </project>
package org.crazyit.app.aspect; /** * Description: * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> * <br/>Copyright (C), 2001-2016, Yeeku.H.Lee * <br/>This program is protected by copyright laws. * <br/>Program Name: * <br/>Date: * @author Yeeku.H.Lee kongyeeku@163.com * @version 1.0 */ public aspect AuthAspect { // 指定在执行org.crazyit.app.service包中任意类的、任意方法之前执行下面代码块 // 第一个星号表示返回值不限;第二个星号表示类名不限; // 第三个星号表示方法名不限;圆括号中..代表任意个数、类型不限的形参 before(): execution(* org.crazyit.app.service.*.*(..)) { System.out.println("模拟进行权限检查..."); } }
package org.crazyit.app.aspect; /** * Description: * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> * <br/>Copyright (C), 2001-2016, Yeeku.H.Lee * <br/>This program is protected by copyright laws. * <br/>Program Name: * <br/>Date: * @author Yeeku.H.Lee kongyeeku@163.com * @version 1.0 */ public aspect LogAspect { // 定义一个PointCut,其名为logPointcut, // 该Pointcut代表了后面给出的切入点表达式,这样可复用该切入点表达式 pointcut logPointcut() :execution(* org.crazyit.app.service.*.*(..)); after():logPointcut() { System.out.println("模拟记录日志..."); } }
package org.crazyit.app.aspect; /** * Description: * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> * <br/>Copyright (C), 2001-2016, Yeeku.H.Lee * <br/>This program is protected by copyright laws. * <br/>Program Name: * <br/>Date: * @author Yeeku.H.Lee kongyeeku@163.com * @version 1.0 */ public aspect TxAspect { // 指定执行Hello.sayHello()方法时执行下面代码块 Object around():call(* org.crazyit.app.service.*.*(..)) { System.out.println("模拟开启事务..."); // 回调原来的目标方法 Object rvt = proceed(); System.out.println("模拟结束事务..."); return rvt; } }
package org.crazyit.app.service; /** * Description: * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> * <br/>Copyright (C), 2001-2016, Yeeku.H.Lee * <br/>This program is protected by copyright laws. * <br/>Program Name: * <br/>Date: * @author Yeeku.H.Lee kongyeeku@163.com * @version 1.0 */ public class World { // 定义一个简单方法,模拟应用中的业务逻辑方法 public void bar() { System.out.println("执行World组件的bar()方法"); } }
package org.crazyit.app.service; /** * Description: * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> * <br/>Copyright (C), 2001-2016, Yeeku.H.Lee * <br/>This program is protected by copyright laws. * <br/>Program Name: * <br/>Date: * @author Yeeku.H.Lee kongyeeku@163.com * @version 1.0 */ public class Hello { // 定义一个简单方法,模拟应用中的业务逻辑方法 public void foo() { System.out.println("执行Hello组件的foo()方法"); } // 定义一个addUser()方法,模拟应用中的添加用户的方法 public int addUser(String name , String pass) { System.out.println("执行Hello组件的addUser添加用户:" + name); return 20; } }