一、Spring的xml配置文件设置
<?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:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd">
<!--使用扫描注解注入的包-->
<context:component-scan base-package="cn.gwj"/>
<!--声明切面类-->
<bean class="cn.gwj.aop.AopLogger"/>
<!--开启使用注解驱动切面-->
<aop:aspectj-autoproxy/>
</beans>
二、三层
package cn.gwj.dao;
import cn.gwj.entity.User;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public class UserDaoImpl implements UserDao{
@Override
public int add() {
throw new RuntimeException("数据异常");
}
}
package cn.gwj.service.user;
import cn.gwj.dao.UserDao;
import cn.gwj.dao.UserDaoImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service("userService")
public class UserServiceImpl implements UserService{
@Autowired
private UserDao userDao;
private String name;
public UserServiceImpl() {}
public String add(String name){
System.out.println("add方法");
UserDaoImpl userDao=new UserDaoImpl();
userDao.add();
return "添加了"+name;
}
}
三、切面类
package cn.gwj.aop;
import cn.gwj.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.apache.log4j.Logger;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import java.util.Arrays;
/**
* 增强类
*/
@Aspect
public class AopLogger {
private Logger logger=Logger.getLogger(AopLogger.class);
@Pointcut("execution(* cn.gwj.service..*.*(..))")
public void pt(){}
@Before("pt()")
public void before(JoinPoint jp){
logger.info("前置增强-执行了"+jp.getTarget()+"的"+jp.getSignature().getName()
+"的方法,传入了参数"+ Arrays.toString(jp.getArgs()));
}
@AfterReturning(pointcut = "pt()",returning = "result")
public void after(JoinPoint jp,Object result){
logger.info("后置增强执行了"+jp.getTarget()+"的"+jp.getSignature().getName()
+"的方法,返回值"+ result);
}
@After("pt()")
public void aft(JoinPoint jp){
logger.info("最终增强-执行了"+jp.getTarget()+"的"+jp.getSignature().getName()
+"的方法");
}
@AfterThrowing(pointcut = "pt()",throwing = "e")
public void exc(JoinPoint jp,RuntimeException e){
logger.info("异常增强-执行了"+jp.getTarget()+"的"+jp.getSignature().getName()
+"的方法,异常"+ e);
}
@Around("pt()")
public Object around(ProceedingJoinPoint pj) throws Throwable {
logger.info(
"前置增强-执行了"+pj.getTarget()+"的"+pj.getSignature().getName()+"方法。方法传参"+Arrays.toString(pj.getArgs())
);
try{
Object result=pj.proceed();
logger.info(
"后置增强-执行了"+pj.getTarget()+"的"+pj.getSignature().getName()
+"的方法,返回值"+ result
);
return result;
}catch (Throwable e){
logger.error("环绕增强"+pj.getSignature().getName()+"方法发生异常。");
throw e;
}finally {
logger.info("环绕增强-"+pj.getSignature().getName()+"方法结束执行。");
}
}
}
四、测试
package cn.gwj.dao;
import cn.gwj.entity.User;
import cn.gwj.service.user.UserService;
import cn.gwj.service.user.UserServiceImpl;
import cn.gwj.util.MyBatisUtil;
import javafx.application.Application;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.SqlSession;
import org.apache.log4j.Logger;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import java.util.ArrayList;
import java.util.List;
/*
Created by IntelliJ IDEA.
Package:cn.gwj.dao
User:1093499975@qq.com
Date:2019/7/6 0006
Time:15:59
*/
public class UserDaoTest {
private Logger logger=Logger.getLogger(UserDaoTest.class);
@Test
public void testAop(){
//通过ClassPathXmlApplicationContext实例化Spring的上下文
ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring-config.xml");
//通过ApplicationContext的getBean()方法,根据id来获取bean的实例
UserService userService=(UserService)applicationContext.getBean("userService");
userService.add("张三");
}
}
五、结果
"C:\Program Files\Java\jdk1.8.0_201\bin\java.exe" -ea -Didea.test.cyclic.buffer.size=1048576 "-javaagent:E:\Program Files\JetBrains\IntelliJ IDEA 2019.1.2\lib\idea_rt.jar=60581:E:\Program Files\JetBrains\IntelliJ IDEA 2019.1.2\bin" -Dfile.encoding=UTF-8 -classpath "E:\Program Files\JetBrains\IntelliJ IDEA 2019.1.2\lib\idea_rt.jar;E:\Program Files\JetBrains\IntelliJ IDEA 2019.1.2\plugins\junit\lib\junit-rt.jar;E:\Program Files\JetBrains\IntelliJ IDEA 2019.1.2\plugins\junit\lib\junit5-rt.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_201\jre\lib\rt.jar;E:\ideaWork\bill\target\test-classes;E:\ideaWork\bill\target\classes;E:\java\apache-maven-3.6.1\m2\maven-repository\junit\junit\4.11\junit-4.11.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\hamcrest\hamcrest-core\1.3\hamcrest-core-1.3.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\mysql\mysql-connector-java\8.0.16\mysql-connector-java-8.0.16.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\com\google\protobuf\protobuf-java\3.6.1\protobuf-java-3.6.1.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\mybatis\mybatis\3.4.1\mybatis-3.4.1.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\log4j\log4j\1.2.17\log4j-1.2.17.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\slf4j\slf4j-api\1.7.18\slf4j-api-1.7.18.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\slf4j\slf4j-log4j12\1.7.18\slf4j-log4j12-1.7.18.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\com\alibaba\fastjson\1.2.58\fastjson-1.2.58.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\javax\servlet\jstl\1.2\jstl-1.2.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\javax\javaee-api\8.0\javaee-api-8.0.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\com\sun\mail\javax.mail\1.6.0\javax.mail-1.6.0.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\javax\activation\activation\1.1\activation-1.1.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\apache\taglibs\taglibs-standard-impl\1.2.5\taglibs-standard-impl-1.2.5.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-core\5.1.8.RELEASE\spring-core-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-jcl\5.1.8.RELEASE\spring-jcl-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-beans\5.1.8.RELEASE\spring-beans-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-tx\5.1.8.RELEASE\spring-tx-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-jdbc\5.1.8.RELEASE\spring-jdbc-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-webmvc\5.1.8.RELEASE\spring-webmvc-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-expression\5.1.8.RELEASE\spring-expression-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-web\5.1.8.RELEASE\spring-web-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-context\5.1.8.RELEASE\spring-context-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-context-support\5.1.8.RELEASE\spring-context-support-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-aop\5.1.8.RELEASE\spring-aop-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\aspectj\aspectjrt\1.9.3\aspectjrt-1.9.3.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\aspectj\aspectjweaver\1.9.3\aspectjweaver-1.9.3.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\springframework\spring-test\5.1.8.RELEASE\spring-test-5.1.8.RELEASE.jar;E:\java\apache-maven-3.6.1\m2\maven-repository\org\mybatis\mybatis-spring\1.3.0\mybatis-spring-1.3.0.jar" com.intellij.rt.execution.junit.JUnitStarter -ideVersion5 -junit4 cn.gwj.dao.UserDaoTest,testAop
07-12 14:54:53[INFO]cn.gwj.aop.AopLogger
-前置增强-执行了cn.gwj.service.user.UserServiceImpl@15bbf42f的add方法。方法传参[张三]
07-12 14:54:53[INFO]cn.gwj.aop.AopLogger
-前置增强-执行了cn.gwj.service.user.UserServiceImpl@15bbf42f的add的方法,传入了参数[张三]
add方法
07-12 14:54:53[ERROR]cn.gwj.aop.AopLogger
-环绕增强add方法发生异常。
07-12 14:54:53[INFO]cn.gwj.aop.AopLogger
-环绕增强-add方法结束执行。
07-12 14:54:53[INFO]cn.gwj.aop.AopLogger
-最终增强-执行了cn.gwj.service.user.UserServiceImpl@15bbf42f的add的方法
07-12 14:54:53[INFO]cn.gwj.aop.AopLogger
-异常增强-执行了cn.gwj.service.user.UserServiceImpl@15bbf42f的add的方法,异常java.lang.RuntimeException: 数据异常
java.lang.RuntimeException: 数据异常
at cn.gwj.dao.UserDaoImpl.add(UserDaoImpl.java:52)
at cn.gwj.service.user.UserServiceImpl.add(UserServiceImpl.java:22)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:343)
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:198)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
at org.springframework.aop.framework.adapter.MethodBeforeAdviceInterceptor.invoke(MethodBeforeAdviceInterceptor.java:56)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:88)
at cn.gwj.aop.AopLogger.around(AopLogger.java:54)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:644)
at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:633)
at org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:70)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.aspectj.AspectJAfterAdvice.invoke(AspectJAfterAdvice.java:47)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.adapter.AfterReturningAdviceInterceptor.invoke(AfterReturningAdviceInterceptor.java:55)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:62)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:93)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:212)
at com.sun.proxy.$Proxy22.add(Unknown Source)
at cn.gwj.dao.UserDaoTest.testAop(UserDaoTest.java:127)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.junit.runner.JUnitCore.run(JUnitCore.java:160)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
Process finished with exit code -1