Spring AOP - Annotation Based After Throwing Advice

@AfterThrowingadalah jenis saran yang memastikan bahwa saran berjalan jika metode tersebut mengeluarkan pengecualian. Berikut adalah sintaks dari saran @AfterThrowing.

Sintaksis

@AfterThrowing(PointCut = "execution(* com.tutorialspoint.Student.*(..))", 
   throwing = "error")
public void afterThrowingAdvice(JoinPoint jp, Throwable error){
   System.out.println("Method Signature: "  + jp.getSignature());  
   System.out.println("Exception: "+error);  
}

Dimana,

  • @AfterThrowing - Tandai fungsi sebagai saran untuk dieksekusi sebelum metode yang dicakup oleh PointCut, jika metode tersebut mengeluarkan pengecualian.

  • PointCut - Memberikan ekspresi untuk memilih fungsi.

  • execution( expression ) - Metode penutup ekspresi di mana saran akan diterapkan.

  • throwing - Nama pengecualian yang akan dikembalikan.

Untuk memahami konsep yang disebutkan di atas terkait dengan Saran @AfterThrowing, mari kita tulis contoh yang akan mengimplementasikan Saran @AfterThrowing. Untuk menulis contoh kami dengan beberapa saran, mari kita memiliki IDE Eclipse yang berfungsi dan gunakan langkah-langkah berikut untuk membuat aplikasi Spring.

Langkah Deskripsi
1 Perbarui proyek yang dibuat Siswa di bawah bab Spring AOP - Application .
2 Perbarui konfigurasi kacang dan jalankan aplikasi seperti yang dijelaskan di bawah ini.

Berikut ini adalah konten dari Logging.javamengajukan. Ini sebenarnya adalah contoh modul aspek, yang mendefinisikan metode yang akan dipanggil di berbagai titik.

package com.tutorialspoint;

import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.JoinPoint;  
import org.aspectj.lang.annotation.AfterThrowing;  

@Aspect
public class Logging {

   /** 
    * This is the method which I would like to execute
    * after a selected method execution throws exception.
    */
   @AfterThrowing(PointCut = "execution(* com.tutorialspoint.Student.*(..))", 
      throwing = "error")
   public void afterThrowingAdvice(JoinPoint jp, Throwable error){
      System.out.println("Method Signature: "  + jp.getSignature());  
      System.out.println("Exception: "+error);  
   }
}

Berikut ini adalah konten dari Student.java mengajukan.

package com.tutorialspoint;

public class Student {
   private Integer age;
   private String name;

   public void setAge(Integer age) {
      this.age = age;
   }
   
   public Integer getAge() {
      System.out.println("Age : " + age );
      return age;
   }

   public void setName(String name) {
      this.name = name;
   }
   
   public String getName() {
      System.out.println("Name : " + name );
      return name;
   }
   
   public void printThrowException(){
      System.out.println("Exception raised");
      throw new IllegalArgumentException();
   }
}

Berikut ini adalah konten dari MainApp.java mengajukan.

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MainApp {
   public static void main(String[] args) {
      ApplicationContext context = 
         new ClassPathXmlApplicationContext("Beans.xml");

      Student student = (Student) context.getBean("student");

      student.printThrowException();     
   }
}

Berikut adalah file konfigurasinya 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"
   xsi:schemaLocation = "http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
   http://www.springframework.org/schema/aop 
   http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">

   <aop:aspectj-autoproxy/>

   <!-- Definition for student bean -->
   <bean id = "student" class = "com.tutorialspoint.Student">
      <property name = "name"  value = "Zara" />
      <property name = "age"  value = "11"/>      
   </bean>

   <!-- Definition for logging aspect -->
   <bean id = "logging" class = "com.tutorialspoint.Logging"/> 
      
</beans>

Jalankan Proyek

Setelah Anda selesai membuat file sumber dan konfigurasi, jalankan aplikasi Anda. Klik kanan pada MainApp.java di aplikasi Anda dan gunakanrun as Java Applicationperintah. Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan mencetak pesan berikut.

Exception raised
Method Signature: void com.tutorialspoint.Student.printThrowException()
Exception: java.lang.IllegalArgumentException
Exception in thread "main" java.lang.IllegalArgumentException
   
   at com.tutorialspoint.Student.printThrowException(Student.java:25)
   
   at com.tutorialspoint.Student$$FastClassBySpringCGLIB$$7dc55815.invoke(<generated>)
   
   at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
   
   at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:717)
   
   at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
   
   at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:58)
   
   at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
   
   at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
   
   at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
   
   at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:653)
   
   at com.tutorialspoint.Student$$EnhancerBySpringCGLIB$$99b0a988.printThrowException(<generated>)
   
   at com.tutorialspoint.MainApp.main(MainApp.java:13)