1.创建如图所示的目录结构
2.编写对应的文件
/*******************************MyAspect 类***********************************/
package com.unicom.aspect;
public class MyAspect {
public void writeLog(){
System.out.println("写日志");
}
}
/****************************UserDao 接口类********************************/
package com.unicom.dao;
public interface UserDao {
public void save();
}
/***************************UserDaoImpl 实现类*******************************/
package com.unicom.dao;
import org.springframework.stereotype.Repository;
@Repository
public class UserDaoImpl implements UserDao {
@Override
public void save() {
System.out.println("dao执行-保存");
}
}
/******************************UserService 接口类*******************************/
package com.unicom.service;
public interface UserService {
public void saveUser();
public void test();
}
/****************************UserServiceImpl 实现类*******************************/
package com.unicom.service;
import com.unicom.dao.UserDao;
import com.unicom.dao.UserDaoImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
@Override
public void saveUser() {
System.out.println("调用业务层 业务层调用dao");
userDao.save();
}
public void test(){
System.out.println("test_show");
}
}
/*******************************UserController 类***********************************/
package com.unicom.web;
import com.unicom.service.UserService;
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;
/*目的 提前让spring加载 配置放到容器*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations= {"classpath:applicationContext.xml"})
public class UserController {
@Autowired
private UserService userService;
@Test
public void service(){
System.out.println("来到Controller");
//调用业务层
userService.saveUser();
userService.test();
}
}
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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd"
>
<!--开启注解扫描-->
<context:component-scan base-package="com.unicom"/>
<!--切面: 内部通知-->
<bean id="myspect" class="com.unicom.aspect.MyAspect"/>
<aop:config>
<!--给谁来增加功能 -->
<aop:pointcut id="pointcut" expression="execution(* com.unicom.service.UserServiceImpl.*(..))"/>
<!--把切面当中的哪一个功能 ,加入到哪一个类当中-->
<aop:aspect ref="myspect">
<aop:after method="writeLog" pointcut-ref="pointcut"></aop:after>
</aop:aspect>
<!--把切面名称为myspect的writeLog通知 给织入到 切入点为pointcut指定方法之后-->
</aop:config>
</beans>
pom.xml文件
<?xml version="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.0</modelVersion>
<groupId>com.unicom</groupId>
<artifactId>SpringProject3</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<!--定义版本号 ${org.springframework.version}-->
<spring.version>5.1.7.RELEASE</spring.version>
</properties>
<dependencies>
<!-- Spring -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.7.RELEASE</version>
</dependency>
<dependency>
<groupId>aopalliance</groupId>
<artifactId>aopalliance</artifactId>
<version>1.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>5.1.7.RELEASE</version>
</dependency>
</dependencies>
</project>