SpringBoot中怎么利用AOP和攔截器實現自定義注解_第1頁
SpringBoot中怎么利用AOP和攔截器實現自定義注解_第2頁
SpringBoot中怎么利用AOP和攔截器實現自定義注解_第3頁
SpringBoot中怎么利用AOP和攔截器實現自定義注解_第4頁
SpringBoot中怎么利用AOP和攔截器實現自定義注解_第5頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第SpringBoot中怎么利用AOP和攔截器實現自定義注解Spring實現自定義注解

通過攔截器+AOP實現自定義注解的實現,在這里攔截器充當在指定注解處要執行的方法,aop負責將攔截器的方法和要注解生效的地方做一個織入(通過動態注解生成代理類實現)。

1.引入相關依賴

spring-boot-starter:spring的一些核心基礎依賴

spring-boot-starter-aop:spring實現Aop的一些相關依賴

dependency

groupIdorg.springframework.boot/groupId

artifactIdspring-boot-starter/artifactId

/dependency

dependency

groupIdorg.springframework.boot/groupId

artifactIdspring-boot-starter-aop/artifactId

/dependency

2.相關類

1.自定義注解類

@Target({ElementType.TYPE})//說明了Annotation所修飾的對象范圍,這里,的作用范圍是類、接口(包括注解類型)或enum

@Retention(RetentionPolicy.RUNTIME)//自定義注解的有效期,Runtime:注解不僅被保存到class文件中,jvm加載class文件之后,仍然存在

@Documented//標注生成javadoc的時候是否會被記錄

public@interfaceEasyExceptionResult{

}

2.攔截器類

*MethodInterceptor是AOP項目中的攔截器(注:不是動態代理攔截器),

*區別與HandlerInterceptor攔截目標時請求,它攔截的目標是方法。

publicclassEasyExceptionIntercepterimplementsMethodInterceptor{

@Override

publicObjectinvoke(MethodInvocationinvocation)throwsThrowable{

AnnotatedElementelement=invocation.getThis().getClass();

EasyExceptionResulteasyExceptionResult=element.getAnnotation(EasyExceptionResult.class);

if(easyExceptionResult==null){

returnceed();

try{

returnceed();

}catch(ExceptionrpcException){

//不同環境下的一個異常處理

System.out.println(發生異常了

returnnull;

}

3.切點切面類

MethodInterceptor的實現類能作為切面的執行方式是應為Interceptor的父類是Advice。

@Configuration

publicclassEasyExceptionAdvisor{

*放在最后執行

*等待ump/日志等記錄結束

*@return{@linkDefaultPointcutAdvisor}對象

@Bean

@Order(Integer.MIN_VALUE)

publicDefaultPointcutAdvisoreasyExceptionResultAdvisor(){

DefaultPointcutAdvisoradvisor=newDefaultPointcutAdvisor();

//針對EasyExceptionResult注解創建切點

AnnotationMatchingPointcutannotationMatchingPointcut=newAnnotationMatchingPointcut(EasyExceptionResult.class,true);

EasyExceptionIntercepterinterceptor=newEasyExceptionIntercepter();

advisor.setPointcut(annotationMatchingPointcut);

//在切點執行interceptor中的invoke方法

advisor.setAdvice(interceptor);

returnadvisor;

}

4.自定義注解的使用

@Service

@EasyExceptionResult//自定義異常捕獲注解

publicclassEasyServiceImpl{

publicvoidtestEasyResult(){

thrownewNullPointerException(測試自定義注解

}

5.效果

@SpringBootApplication

publicclassJdStudyApplication{

publicstaticvoidmAIn(String[]args){

ConfigurableApplicationContextcontext=SpringApplication.run(JdStudyApplication.class,args);

EasyServiceImpleasyService=context.getBean(EasyServiceImpl.class);

easyService.testEasyResult();

}

至此就實現了通過spring實現自定義注解。

Java實現自定義注解

雖然通過Spring實現了自定義注解但是還有辦法讓我們不通過Spring也能實現自定義注解,畢竟注解是早于Spring的。

JDK中有一些元注解,主要有@Target,@Retention,@Document,@Inherited用來修飾注解,如下為一個自定義注解。

@Target({ElementType.TYPE})//說明了Annotation所修飾的對象范圍,這里,的作用范圍是類、接口(包括注解類型)或enum

@Retention(RetentionPolicy.RUNTIME)//自定義注解的有效期,Ru

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論