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上 -基於註解配置bean,動態代理,AOP筆記SpringBean筆記
- Spring基於註解的IoC配置Spring
- Spring基於註解實現 AOP 切面功能Spring
- 死磕Spring之AOP篇 - Spring AOP註解驅動與XML配置SpringXML
- Spring AOP的AspectJ註解Spring
- spring基於註解配置實現事務控制Spring
- 基於AOP的MVP框架(三)GoMVP進階註解MVP框架Go
- 基於AOP的MVP框架(二)GoMVP進階註解MVP框架Go
- Spring5(七)——AOP註解Spring
- Spring Boot系列十八 Spring AOP + 註解實現統一註解Spring Boot
- Spring7——開發基於註解形式的springSpring
- Spring Boot 基於註解驅動原始碼分析--自動配置Spring Boot原始碼
- spring事物配置,宣告式事務管理和基於@Transactional註解的使用Spring
- SpringBoot基於註解方式配置FilterSpring BootFilter
- Spring中基於XML方式的AOP操作SpringXML
- Spring AOP基於xml的方式實現SpringXML
- Spring(使用註解配置)Spring
- Spring Boot配置類的註解Spring Boot
- 基於SpringBoot 、AOP與自定義註解轉義字典值Spring Boot
- 基於Spring-AOP的自定義分片工具Spring
- Spring系列:基於Spring-AOP和Spring-Aspects實現AOP切面程式設計Spring程式設計
- Spring / Spring boot 基於註解非同步程式設計@AsyncSpring Boot非同步程式設計
- Spring第9天Aop簡介,Aopxml開發,Aop註解開發SpringXML
- Spring系列之新註解配置+Spring整合junit+註解注入Spring
- Spring學習筆記2(IOC註解方式&AOP)Spring筆記
- spring配置redis註解快取SpringRedis快取
- 基於註解的方式使用spring-integration-redis分散式鎖SpringRedis分散式
- spring-AOP(二)實現原理之AspectJ註解方式Spring
- Spring系列之aAOP AOP是什麼?+xml方式實現aop+註解方式實現aopSpringXML
- Spring零配置之@Configuration註解詳解Spring
- spring boot基於Java的容器配置Spring BootJava
- Spring AOP 詳解Spring
- Spring AOP及事務配置三種模式詳解Spring模式
- Spring 常用的註解以及對應 XML 配置詳解SpringXML
- spring應用手冊-AOP(註解)-(20)-切面釋出-前置通知Spring
- 從XML配置角度理解Spring AOPXMLSpring