spring aop的用法
-
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yVyhbhAF-1604204613047)(images_java aop用法/image-20201101120649150.png)]
-
AnnotationPointCut 切面类
package com.kuang.diy; //方式三:使用注解方式实现AOP import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.Signature; import org.aspectj.lang.annotation.*; @Aspect //标注这个类是一个切面 public class AnnotationPointCut { @Before("execution(* com.kuang.service.UserServiceImpl.*(..))") public void before(){ System.out.println("=====方法执行前======"); } @AfterReturning("execution(* com.kuang.service.UserServiceImpl.*(..))") public void afterReturning(){ System.out.println("方法执行后之后"); } @After("execution(* com.kuang.service.UserServiceImpl.*(..))") public void after(){ System.out.println("=====方法执行后======"); } //在环绕增强中,我们可以给定一个参数,代表我们要获取处理切入的点; @Around("execution(* com.kuang.service.UserServiceImpl.*(..))") public void around(ProceedingJoinPoint jp) throws Throwable { System.out.println("环绕前"); Signature signature = jp.getSignature();//获得签名 System.out.println("signature:"+signature); Object proceed = jp.proceed(); //执行方法 System.out.println("环绕后"); System.out.println("wgy" + proceed); } }
-
定义一个接口,然后实现这个借口
package com.kuang.service; public interface UserService { public void add(); public void delete(); public void update(); public void select(); } package com.kuang.service; public class UserServiceImpl implements UserService { public void add() { System.out.println("增加了一个用户"); } public void delete() { System.out.println("删除了一个用户"); } public void update() { System.out.println("更新了一个用户"); } public void select() { System.out.println("查询了一个用户"); } }
-
bean 配置文件applicationContext.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" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd"> <!--注册bean--> <bean id="userService" class="com.kuang.service.UserServiceImpl"/> <bean id="log" class="com.kuang.log.Log"/> <bean id="afterLog" class="com.kuang.log.AfterLog"/> <!--方式三--> <bean id="annotationPointCut" class="com.kuang.diy.AnnotationPointCut"/> <!--开启注解支持! JDK(默认 proxy-target-class="false") cglib(proxy-target-class="true")--> <aop:aspectj-autoproxy/> <!--方式一:使用原生Spring API接口 --> <!--配置aop:需要导入aop的约束--> <!-- <aop:config>--> <!-- <!–切入点:expression:表达式,execution(要执行的位置! * * * * *) –>--> <!-- <aop:pointcut id="pointcut" expression="execution(* com.kuang.service.UserServiceImpl.*(..))"/>--> <!-- <!–执行环绕增加!–>--> <!-- <aop:advisor advice-ref="log" pointcut-ref="pointcut"/>--> <!-- <aop:advisor advice-ref="afterLog" pointcut-ref="pointcut"/>--> <!-- </aop:config>--> <!--方式二:自定义类--> <!--<bean id="diy" class="com.kuang.diy.DiyPointCut"/>--> <!--<aop:config>--> <!--<!–自定义切面, ref 要引用的类–>--> <!--<aop:aspect ref="diy">--> <!--<!–切入点–>--> <!--<aop:pointcut id="point" expression="execution(* com.kuang.service.UserServiceImpl.*(..))"/>--> <!--<!–通知–>--> <!--<aop:before method="before" pointcut-ref="point"/>--> <!--<aop:after method="after" pointcut-ref="point"/>--> <!--</aop:aspect>--> <!--</aop:config>--> </beans>
-
测试类
import com.kuang.service.UserService; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class MyTest { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); //动态代理代理的是接口:注意点 UserService userService = (UserService) context.getBean("userService"); userService.delete(); } }
-
运行结果
"C:\Program Files\Java\jdk1.8.0_201\bin\java.exe" "-javaagent:D:\Program Files\ideaIU-2020.2.win\lib\idea_rt.jar=13571:D:\Program Files\ideaIU-2020.2.win\bin" -Dfile.encoding=UTF-8 -classpath "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;F:\code\java\SpringBootTest\springaop\springaop01\target\test-classes;F:\code\java\SpringBootTest\springaop\springaop01\target\classes;C:\Users\wgy\.m2\repository\org\springframework\spring-webmvc\5.2.0.RELEASE\spring-webmvc-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-aop\5.2.0.RELEASE\spring-aop-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-beans\5.2.0.RELEASE\spring-beans-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-context\5.2.0.RELEASE\spring-context-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-core\5.2.0.RELEASE\spring-core-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-jcl\5.2.0.RELEASE\spring-jcl-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-expression\5.2.0.RELEASE\spring-expression-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\org\springframework\spring-web\5.2.0.RELEASE\spring-web-5.2.0.RELEASE.jar;C:\Users\wgy\.m2\repository\junit\junit\4.12\junit-4.12.jar;C:\Users\wgy\.m2\repository\org\hamcrest\hamcrest-core\1.3\hamcrest-core-1.3.jar;C:\Users\wgy\.m2\repository\org\aspectj\aspectjweaver\1.9.4\aspectjweaver-1.9.4.jar" MyTest 环绕前 signature:void com.kuang.service.UserService.delete() =====方法执行前====== 删除了一个用户 环绕后 wgynull =====方法执行后====== 方法执行后之后 Process finished with exit code 0