Log.java:
package log;
public class Log {
public void before(){
System.out.println("方法执行前");
}
public void after(){
System.out.println("方法执行后");
}
}
UserService.java:
package service;
public interface UserService {
public void add();
public void delete();
public void search();
public void update();
}
UserServiceImp.java:
package service;
public class UserServiceImp implements UserService {
@Override
public void add() {
System.out.println("增加用户");
}
@Override
public void delete() {
System.out.println("删除用户");
}
@Override
public void search() {
System.out.println("查找用户");
}
@Override
public void update() {
System.out.println("修改用户");
}
}
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
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd">
<bean id="userService" class="service.UserServiceImp"/>
<bean id="log" class="log.Log"/>
<aop:config>
<aop:aspect ref="log">
<aop:pointcut id="pointut" expression="execution(* service.UserServiceImp.*(..))"/>
<aop:before method="before" pointcut-ref="pointut"/>
<aop:after method="after" pointcut-ref="pointut"/>
</aop:aspect>
</aop:config>
</beans>
Test.java:
package test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import service.UserService;
public class Test {
public static void main(String[] args) {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");
UserService userService = (UserService) applicationContext.getBean("userService");
userService.add();
}
}
测试结果:
方法执行前
增加用户
方法执行后
可以加我微信一起学习: