Spring AOP相关概念,比如切面(Aspect)、增强(也要叫“通知”的,Advice)、切入点(Pointcut)、连接点(JoinPoint)、目标对象(Target)等这里不做介绍。直接上Demo,讲述如何在项目中应用AOP记录日志。
一、先给出相关类:
1.切面类(Aspect):采用annotation注解方式
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
@Aspect
public class SecurityAspect {
@Pointcut("execution(* com.aop.DemoImpl.add*(..)) || execution(* del*(..))")
private void allAddMethod() {
};
@Before("allAddMethod()")
private void checkSecurity() {
System.out.println("-----开始检查安全了!-----");
}
@AfterReturning("allAddMethod()")
private void addLog(JoinPoint point){
System.out.println(point.getTarget().getClass().toString());
[b]Object objArgsObject = point.getArgs()[0];[/b]
System.out.println(objArgsObject.toString());
System.out.println("------开始记录日志了!------");
}
}
注意粗体部分,获得代理目标方法参数的方法。在第二部分详细说明。
2.业务类
接口:
public interface IDemo{
public void addUser(String username, String password);
public void deleteUser(int id);
public void modifyUser(int id, String username, String password);
public String findUserById(int id);
}
实现:
public class DemoImpl implements IDemo{
public void addUser(String username, String password) {
// TODO Auto-generated method stub
System.out.println("##增加了一个用户!##");
}
public void deleteUser(int id) {
// TODO Auto-generated method stub
System.out.println("##删除了标志为id的用户##");
}
public String findUserById(int id) {
// TODO Auto-generated method stub
System.out.println("##查询用户##");
return null;
}
public void modifyUser(int id, String username, String password) {
// TODO Auto-generated method stub
System.out.println("##修改用户##");
}
}
二、相关说明即配置
1.applicationContext.xml文件:
注意引入相关头,可对照下面配置:
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"
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"
default-autowire="byName" default-lazy-init="true">
2.测试代码:
public class Client {
public static void main(String[] args) {
BeanFactory factory = new ClassPathXmlApplicationContext(
"applicationContext.xml");
IDemo demo= (IDemo) factory.getBean("demo");
demo.addUser("刘德华", "123");
demo.deleteUser(1);
demo.modifyUser(1, "刘德华", "password");
}
}
运行结果大致如下:
-----开始检查安全了!-----
##增加了一个用户!##
------开始记录日志了!------
-----开始检查安全了!-----
##删除了标志为id的用户##
------开始记录日志了!------
1
"##修改用户##"
注:其中打印的1为代理的目标方法的第一个参数,切面类中可以获得deleteUser,modifyUser所有的参数。获取连接点方法主要是利用JoinPoint中的getArgs方法,其中还有其它方法可自行研究。