Spring AOP记录日志

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文件:
<!-- Spring AOP相关配置开始 -->
<aop:aspectj-autoproxy /><!-- 支持 @AspectJ 标记-->
<bean id="securityaspect" class="com.aop.SecurityAspect" />
<bean id="demo" class="com.aop.DemoImpl" />
注意引入相关头,可对照下面配置:
<?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"
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方法,其中还有其它方法可自行研究。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值