Spring AOP - Anotasi Kustom
Sesuai ekspresi PointCut, mungkin saja mereka diterapkan ke beberapa kacang lain yang sarannya tidak dimaksudkan. Misalnya, perhatikan ekspresi berikut.
execution(* com.tutorialspoint.*.getAge(..))
Kacang pegas baru ditambahkan dengan metode getAge () dan saran akan mulai diterapkan padanya meskipun mungkin tidak dimaksudkan. Untuk mencapai hal ini, kita dapat membuat anotasi khusus dan memberi anotasi pada metode yang akan digunakan saran tersebut.
@Before("@annotation(com.tutorialspoint.Loggable)")
Untuk memahami konsep yang disebutkan di atas terkait dengan @Before Advice, mari kita tulis contoh yang akan mengimplementasikan @Before Advice. 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.annotation.Before;
@Aspect
public class Logging {
/**
* This is the method which I would like to execute
* before a selected method execution.
*/
@Before("@annotation(com.tutorialspoint.Loggable)")
public void beforeAdvice(){
System.out.println("Going to setup student profile.");
}
}
Berikut ini adalah konten dari Loggable.java file -
package com.tutorialspoint;
public @interface Loggable {
}
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;
}
@Loggable
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.getName();
student.getAge();
}
}
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.
Going to setup student profile.
Name : Zara
Age : 11