Spring AOP - Implementasi
Spring mendukung @AspectJ annotation style pendekatan dan schema-based pendekatan untuk menerapkan aspek adat.
Berbasis Skema XML
Aspek diimplementasikan menggunakan kelas reguler bersama dengan konfigurasi berbasis XML.
Untuk menggunakan tag ruang nama AOP yang dijelaskan di bagian ini, Anda perlu mengimpor skema AOP pegas, yang dijelaskan sebagai berikut -
<?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 ">
<!-- bean definition & AOP specific configuration -->
</beans>
Mendeklarasikan Aspek
Sebuah aspect dideklarasikan menggunakan <aop:aspect> elemen, dan kacang pendukung direferensikan menggunakan ref atribut sebagai berikut.
<aop:config>
<aop:aspect id = "myAspect" ref = "aBean">
...
</aop:aspect>
</aop:config>
<bean id = "aBean" class = "...">
...
</bean>
Di sini "aBean" akan dikonfigurasi dan ketergantungan disuntikkan seperti kacang Spring lainnya seperti yang Anda lihat di bab sebelumnya.
Mendeklarasikan PointCut
SEBUAH PointCutmembantu dalam menentukan titik bergabung (yaitu metode) yang menarik untuk dieksekusi dengan saran yang berbeda. Saat bekerja dengan konfigurasi berbasis XML Schema, PointCut akan didefinisikan sebagai berikut -
<aop:config>
<aop:aspect id = "myAspect" ref = "aBean">
<aop:PointCut id = "businessService"
expression = "execution(* com.xyz.myapp.service.*.*(..))"/>
...
</aop:aspect>
</aop:config>
<bean id = "aBean" class = "...">
...
</bean>
Contoh berikut mendefinisikan PointCut bernama 'businessService' yang akan cocok dengan eksekusi metode getName () yang tersedia di kelas Mahasiswa di bawah paket com.tutorialspoint.
<aop:config>
<aop:aspect id = "myAspect" ref = "aBean">
<aop:PointCut id = "businessService"
expression = "execution(* com.tutorialspoint.Student.getName(..))"/>
...
</aop:aspect>
</aop:config>
<bean id = "aBean" class = "...">
...
</bean>
Mendeklarasikan Saran
Anda dapat mendeklarasikan salah satu dari lima nasihat di dalam <aop: aspect> menggunakan elemen <aop: {ADVICE NAME}> sebagai berikut.
<aop:config>
<aop:aspect id = "myAspect" ref = "aBean">
<aop:PointCut id = "businessService"
expression = "execution(* com.xyz.myapp.service.*.*(..))"/>
<!-- a before advice definition -->
<aop:before PointCut-ref = "businessService"
method = "doRequiredTask"/>
<!-- an after advice definition -->
<aop:after PointCut-ref = "businessService"
method = "doRequiredTask"/>
<!-- an after-returning advice definition -->
<!--The doRequiredTask method must have parameter named retVal -->
<aop:after-returning PointCut-ref = "businessService"
returning = "retVal"
method = "doRequiredTask"/>
<!-- an after-throwing advice definition -->
<!--The doRequiredTask method must have parameter named ex -->
<aop:after-throwing PointCut-ref = "businessService"
throwing = "ex"
method = "doRequiredTask"/>
<!-- an around advice definition -->
<aop:around PointCut-ref = "businessService"
method = "doRequiredTask"/>
...
</aop:aspect>
</aop:config>
<bean id = "aBean" class = "...">
...
</bean>
Anda bisa menggunakan yang sama doRequiredTaskatau metode berbeda untuk saran yang berbeda. Metode ini akan ditetapkan sebagai bagian dari modul aspek.
Berbasis @Aspect
@AspectJ mengacu pada gaya mendeklarasikan aspek sebagai kelas Java reguler yang dianotasi dengan anotasi Java 5. Dukungan @AspectJ diaktifkan dengan menyertakan elemen berikut di dalam file konfigurasi berbasis Skema XML Anda.
<aop:aspectj-autoproxy/>
Mendeklarasikan Aspek
Kelas Aspects seperti kacang normal lainnya dan mungkin memiliki metode dan bidang seperti kelas lainnya, kecuali bahwa mereka akan dianotasi dengan @Aspect sebagai berikut.
package org.xyz;
import org.aspectj.lang.annotation.Aspect;
@Aspect
public class AspectModule {
}
Mereka akan dikonfigurasi dalam XML seperti kacang lainnya sebagai berikut.
<bean id = "myAspect" class = "org.xyz.AspectModule">
<!-- configure properties of aspect here as normal -->
</bean>
Mendeklarasikan PointCut
SEBUAH PointCutmembantu dalam menentukan titik bergabung (yaitu metode) yang menarik untuk dieksekusi dengan saran yang berbeda. Saat bekerja dengan konfigurasi berbasis @AspectJ, deklarasi PointCut memiliki dua bagian -
Ekspresi PointCut yang menentukan dengan tepat eksekusi metode mana yang kami minati.
Tanda tangan PointCut terdiri dari nama dan sejumlah parameter. Isi sebenarnya dari metode tersebut tidak relevan dan sebenarnya harus kosong.
Contoh berikut mendefinisikan PointCut bernama 'businessService' yang akan cocok dengan eksekusi setiap metode yang tersedia di kelas di bawah paket com.xyz.myapp.service.
import org.aspectj.lang.annotation.PointCut;
@PointCut("execution(* com.xyz.myapp.service.*.*(..))") // expression
private void businessService() {} // signature
Contoh berikut mendefinisikan PointCut bernama 'getname' yang akan cocok dengan eksekusi metode getName () yang tersedia di kelas Student di bawah paket com.tutorialspoint.
import org.aspectj.lang.annotation.PointCut;
@PointCut("execution(* com.tutorialspoint.Student.getName(..))")
private void getname() {}
Mendeklarasikan Saran
Anda dapat mendeklarasikan salah satu dari lima nasihat menggunakan anotasi @ {NAMA SARAN} seperti yang diberikan di bawah ini. Ini mengasumsikan bahwa Anda telah menetapkan metode tanda tangan PointCut businessService ().
@Before("businessService()")
public void doBeforeTask(){
...
}
@After("businessService()")
public void doAfterTask(){
...
}
@AfterReturning(PointCut = "businessService()", returning = "retVal")
public void doAfterReturnningTask(Object retVal){
// you can intercept retVal here.
...
}
@AfterThrowing(PointCut = "businessService()", throwing = "ex")
public void doAfterThrowingTask(Exception ex){
// you can intercept thrown exception here.
...
}
@Around("businessService()")
public void doAroundTask(){
...
}
Anda dapat menentukan PointCut inline untuk salah satu saran. Berikut adalah contoh untuk mendefinisikan inline PointCut untuk saran sebelumnya.
@Before("execution(* com.xyz.myapp.service.*.*(..))")
public doBeforeTask(){
...
}