Spring基於註解的aop配置
Spring基於註解的aop配置
1.配置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:context="http://www.springframework.org/schema/context"
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
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
</beans>
完善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:context="http://www.springframework.org/schema/context"
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
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--配置Spring容器建立時候要掃描的包-->
<context:component-scan base-package="com.itheima"></context:component-scan>
<!--配置Spring開啟註解aop的支援-->
<aop:aspectj-autoproxy></aop:aspectj-autoproxy>
2.使用註解將AccountService和Logger物件的建立交給Spring 容器,同時用@Aspect註解表示當前是個切面類(我自己的說法:通俗的說就是通知類)
3.使用@Before、@AfterReturning、@AfterThrowing、@After、@Around註解表示當前方法是前置通知、後置通知、異常通知、最終通知還是環繞通知
/*
* 用於記錄日誌的工具類,提供了公共程式碼
* 或者說可以理解為通知類。切入點和通知類結合成為切面*/
@Component("logger")
@Aspect//表示當前類是一個切面類
public class Logger {
/*
* 用於列印日誌,計劃在切入點方法執行前執行。切入點方法就是業務層方法,也可以稱為被增強的方法*/
@Before("execution(* com.itheima.service.Impl.*.*(..))")
public void printLog(){
System.out.println("Logger類中的方法開始記錄日誌");
}
@AfterReturning("execution(* com.itheima.service.Impl.*.*(..))")
public void afterReturning(){
System.out.println("記錄完畢");
}
@AfterThrowing("execution(* com.itheima.service.Impl.*.*(..))")
public void throsAdvice(){
System.out.println("有異常");
}
@After("execution(* com.itheima.service.Impl.*.*(..))")
public void after(){
System.out.println("finally");
}
}
使用註解也可以配置切入點表示式
執行結果:
如果想使用純註解的AOP可是使用@EnableAspectJAutoProxy
相關文章
- Spring Aop基於註解的實現Spring
- Spring基於註解的AOP測試Spring
- Spring中基於註解方式的AOP操作Spring
- spring上 -基於註解配置bean,動態代理,AOP筆記SpringBean筆記
- Spring基於註解的IoC配置Spring
- Spring AOP的AspectJ註解Spring
- 死磕Spring之AOP篇 - Spring AOP註解驅動與XML配置SpringXML
- spring基於註解配置實現事務控制Spring
- Java Web之基於註解的Spring MVC環境配置JavaWebSpringMVC
- spring 05 aop_註解Spring
- 基於註解的 Spring MVC詳解SpringMVC
- Spring(5、基於註解的事物)Spring
- Spring 註解方式實現的AOPSpring
- 基於註解的Spring多資料來源配置和使用Spring
- 基於AOP的MVP框架(三)GoMVP進階註解MVP框架Go
- 基於AOP的MVP框架(二)GoMVP進階註解MVP框架Go
- Spring5(七)——AOP註解Spring
- Spring-Aop註解形式案例Spring
- Spring Boot系列十八 Spring AOP + 註解實現統一註解Spring Boot
- Spring7:基於註解的Spring MVC(下篇)SpringMVC
- Spring6:基於註解的Spring MVC(上篇)SpringMVC
- Spring Boot 基於註解驅動原始碼分析--自動配置Spring Boot原始碼
- spring事物配置,宣告式事務管理和基於@Transactional註解的使用Spring
- Spring7——開發基於註解形式的springSpring
- Spring中基於XML方式的AOP操作SpringXML
- Spring AOP基於xml的方式實現SpringXML
- 基於註解的Spring多資料來源配置和使用(非事務)Spring
- Spring(使用註解配置)Spring
- Spring Boot配置類的註解Spring Boot
- 基於Spring-AOP的自定義分片工具Spring
- SpringBoot基於註解方式配置FilterSpring BootFilter
- 基於SpringBoot 、AOP與自定義註解轉義字典值Spring Boot
- Spring第9天Aop簡介,Aopxml開發,Aop註解開發SpringXML
- linux 安裝mysql和主從配置 + Spring 基於註解配置mysql讀寫分離LinuxMySqlSpring
- spring通過註解配置Spring
- Spring學習筆記2(IOC註解方式&AOP)Spring筆記
- 通過 Spring AOP 註解實現自動代理Spring
- Spring / Spring boot 基於註解非同步程式設計@AsyncSpring Boot非同步程式設計