案例设定:测算接口执行效率,但是这个案例稍微复杂了点,我们对其进行简化。
简化设定:在方法执行前输出当前系统时间。
对于SpringAOP的开发有两种方式,XML 和 ==注解==,我们使用哪个呢?
因为现在注解使用的比较多,所以本次课程就采用注解完成AOP的开发。
总结需求为:使用SpringAOP的注解方式完成在方法执行的前打印出当前系统时间。
需求明确后,具体该如何实现,都有哪些步骤,我们先来分析下:
1.导入坐标(pom.xml)
2.制作连接点(原始操作,Dao接口与实现类)
3.制作共性功能(通知类与通知)
4.定义切入点
5.绑定切入点与通知关系(切面)

- "1.0" encoding="UTF-8"?>
- <project xmlns="http://maven.apache.org/POM/4.0.0"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0modelVersion>
-
- <groupId>org.examplegroupId>
- <artifactId>SpringAopartifactId>
- <version>1.0-SNAPSHOTversion>
- <dependencies>
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-contextartifactId>
- <version>5.2.10.RELEASEversion>
- dependency>
- <dependency>
- <groupId>org.aspectjgroupId>
- <artifactId>aspectjweaverartifactId>
- <version>1.9.4version>
- dependency>
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-testartifactId>
- <version>5.2.10.RELEASEversion>
- dependency>
- dependencies>
-
- <properties>
- <maven.compiler.source>8maven.compiler.source>
- <maven.compiler.target>8maven.compiler.target>
- properties>
-
- project>
- package com.itheima.dao;
-
- public interface book {
- public void save();
- public void update();
- }
-
-
- package com.itheima.dao.impl;
-
- import com.itheima.dao.book;
- import org.springframework.stereotype.Repository;
-
- @Repository
- public class bookimpl implements book {
- @Override
- public void save() {
- System.out.println("方法1");
- }
-
- @Override
- public void update() {
- System.out.println("方法2");
-
- }
- }

- package com.itheima.SpringConfig;
-
- import org.springframework.context.annotation.ComponentScan;
- import org.springframework.context.annotation.EnableAspectJAutoProxy;
- import org.springframework.stereotype.Component;
-
- @Component
- @ComponentScan("com.itheima")
- @EnableAspectJAutoProxy
- public class SpringConfig {
- }


- package com.itheima.aop;
-
- import org.aspectj.lang.annotation.Aspect;
- import org.aspectj.lang.annotation.Before;
- import org.aspectj.lang.annotation.Pointcut;
- import org.springframework.stereotype.Component;
-
- @Component
- @Aspect
- public class bookaop {
-
- //绑定连接点
- @Pointcut("execution(void com.itheima.dao.book.save())")
- private void bb(){};
- //绑定切面
- @Before("bb()")
- //创建通知
- public void kk(){
- System.out.println("郭浩康加油");
- }
- }
- package com.itheima;
-
- import com.itheima.SpringConfig.SpringConfig;
- import com.itheima.dao.book;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.annotation.AnnotationConfigApplicationContext;
-
- public class APP {
- public static void main(String[] args) {
- ApplicationContext ctx=new AnnotationConfigApplicationContext(SpringConfig.class);
- book book = ctx.getBean(book.class);
- book.save();
-
- }
- }
- package com.itheima;
-
- import com.itheima.SpringConfig.SpringConfig;
- import com.itheima.dao.book;
- import org.junit.Test;
- import org.junit.runner.RunWith;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.test.context.ContextConfiguration;
- import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
-
- @RunWith(SpringJUnit4ClassRunner.class)
- @ContextConfiguration(classes = SpringConfig.class)
- public class test {
- @Autowired
- private book bk;
-
- @Test
- public void testsave(){
- bk.save();
- }
- }
