Spring AOP - Panduan Cepat

Salah satu komponen kunci dari Spring Framework adalah Aspect Oriented Programming (AOP)kerangka. Pemrograman Berorientasi Aspek memerlukan pemecahan logika program menjadi bagian-bagian berbeda yang disebutso-called concerns. Fungsi yang menjangkau banyak titik dari suatu aplikasi disebut masalah lintas sektoral. Inicross-cutting concernssecara konseptual terpisah dari logika bisnis aplikasi. Ada berbagai contoh bagus dari aspek seperti logging, audit, transaksi deklaratif, keamanan, caching, dll.

Unit kunci dari modularitas di OOP adalah class, sedangkan di AOP unit modularity adalah aspeknya. Dependency Injection membantu Anda memisahkan objek aplikasi dari satu sama lain, sementara AOP membantu Anda memisahkan masalah lintas sektor dari objek yang terpengaruh. AOP seperti pemicu dalam bahasa pemrograman seperti Perl, .NET, Java, dan lainnya.

Modul Spring AOP memungkinkan interseptor mencegat aplikasi. Misalnya, ketika sebuah metode dijalankan, Anda dapat menambahkan fungsionalitas tambahan sebelum atau setelah eksekusi metode.

Bab ini memandu Anda melalui proses menyiapkan Spring AOP di sistem berbasis Windows dan Linux. Spring AOP dapat dengan mudah diinstal dan diintegrasikan dengan lingkungan Java dan MAVEN Anda saat ini dengan mengikuti beberapa langkah sederhana tanpa prosedur penyiapan yang rumit. Administrasi pengguna diperlukan saat instalasi.

Persyaratan sistem

JDK Java SE 2 JDK 1.5 atau lebih tinggi
Penyimpanan RAM 1 GB (disarankan)
Ruang Disk Tidak ada persyaratan minimum
Versi Sistem Operasi Windows XP atau yang lebih baru, Linux

Sekarang mari kita lihat langkah-langkah untuk menginstal Spring AOP.

Langkah 1: Verifikasi Instalasi Java Anda

Pertama-tama, Anda harus menginstal Java Software Development Kit (SDK) di sistem Anda. Untuk memverifikasi ini, jalankan salah satu dari dua perintah berikut tergantung pada platform yang Anda kerjakan.

Jika penginstalan Java sudah dilakukan dengan benar, maka versi dan spesifikasi penginstalan Java Anda saat ini akan ditampilkan. Output sampel diberikan dalam tabel berikut.

Peron Perintah Output Sampel
Windows

Buka konsol perintah dan ketik -

\>java -version

Versi Java "1.7.0_60"

Java (TM) SE Run Time Environment (build 1.7.0_60-b19)

Java Hotspot (TM) 64-bit Server VM (build 24.60-b09, mode campuran)

Linux

Buka terminal perintah dan ketik -

$java -version

versi java "1.7.0_25"

Buka JDK Runtime Environment (rhel-2.3.10.4.el6_4-x86_64)

Buka VM Server JDK 64-Bit (build 23.7-b01, mode campuran)

Kami berasumsi bahwa pembaca tutorial ini telah menginstal Java SDK versi 1.7.0_60 di sistem mereka.

Jika Anda tidak memiliki Java SDK, unduh versi saat ini dari https://www.oracle.com/technetwork/java/javase/downloads/index.html dan menginstalnya.

Langkah 2: Setel Lingkungan Java Anda

Setel variabel lingkungan JAVA_HOME agar mengarah ke lokasi direktori dasar tempat Java diinstal pada mesin Anda. Sebagai contoh,

Sr.No. Platform & Deskripsi
1

Windows

Setel JAVA_HOME ke C: \ ProgramFiles \ java \ jdk1.7.0_60

2

Linux

Ekspor JAVA_HOME = / usr / local / java-current

Tambahkan jalur lengkap lokasi kompilator Java ke Jalur Sistem.

Sr.No. Platform & Deskripsi
1

Windows

Tambahkan String "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" di akhir Path variabel sistem.

2

Linux

Ekspor PATH = $ PATH: $ JAVA_HOME / bin /

Jalankan perintahnya java -version dari command prompt seperti dijelaskan di atas.

Langkah 3: Unduh Arsip Maven

Unduh Maven 3.3.3 dari https://maven.apache.org/download.cgi

OS Nama Arsip
Windows apache-maven-3.3.3-bin.zip
Linux apache-maven-3.3.3-bin.tar.gz
Mac apache-maven-3.3.3-bin.tar.gz

Langkah 4: Ekstrak Arsip Maven

Ekstrak arsip, ke direktori tempat Anda ingin menginstal Maven 3.3.3. Subdirektori apache-maven-3.3.3 akan dibuat dari arsip.

OS Lokasi (dapat berbeda berdasarkan instalasi Anda)
Windows C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3
Linux / usr / local / apache-maven
Mac / usr / local / apache-maven

Langkah 5: Tetapkan Variabel Lingkungan Maven

Tambahkan M2_HOME, M2, MAVEN_OPTS ke variabel lingkungan.

OS Keluaran
Windows

Setel variabel lingkungan menggunakan properti sistem.

M2_HOME = C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3

M2 =% M2_HOME% \ bin

MAVEN_OPTS = -Xms256m -Xmx512m

Linux Buka terminal perintah dan atur variabel lingkungan.

ekspor M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3

ekspor M2 = $ M2_HOME / bin

ekspor MAVEN_OPTS = -Xms256m -Xmx512m

Mac

Buka terminal perintah dan atur variabel lingkungan.

ekspor M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3

ekspor M2 = $ M2_HOME / bin

ekspor MAVEN_OPTS = -Xms256m -Xmx512m

Langkah 6: Tambahkan Lokasi Direktori Maven Bin ke Jalur Sistem

Sekarang tambahkan variabel M2 ke Jalur Sistem.

OS Keluaran
Windows Tambahkan string;% M2% ke akhir variabel sistem, Path.
Linux ekspor PATH = $ M2: $ PATH
Mac ekspor PATH = $ M2: $ PATH

Langkah 7: Verifikasi instalasi Maven

Sekarang buka konsol, dan jalankan perintah berikut mvn perintah.

OS Tugas Perintah
Windows Buka Konsol Perintah c: \> mvn --version
Linux Buka Terminal Perintah $ mvn --version
Mac Buka Terminal mesin: <joseph $ mvn --version

Terakhir, verifikasi output dari perintah di atas, yang seharusnya seperti berikut -

OS Keluaran
Windows

Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30)

Beranda Maven: C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3

Versi Java: 1.7.0_75, vendor: Oracle Corporation

Rumah Java: C: \ Program Files \ Java \ jdk1.7.0_75 \ jre

Lokal default: en_US, encoding platform: Cp1252

Linux

Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30)

Rumah Maven: /usr/local/apache-maven/apache-maven-3.3.3

Versi Java: 1.7.0_75, vendor: Oracle Corporation

Beranda Java: /usr/local/java-current/jdk1.7.0_75/jre

Mac

Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30)

Rumah Maven: /usr/local/apache-maven/apache-maven-3.3.3

Versi Java: 1.7.0_75, vendor: Oracle Corporation

Beranda Java: /Library/Java/Home/jdk1.7.0_75/jre

Langkah 8 - Siapkan Eclipse IDE

Semua contoh dalam tutorial ini telah ditulis menggunakan Eclipse IDE. Jadi saya sarankan Anda harus menginstal Eclipse versi terbaru di komputer Anda.

Untuk menginstal Eclipse IDE, unduh binari Eclipse terbaru dari https://www.eclipse.org/downloads/. Setelah Anda mengunduh instalasi, buka paket distribusi biner ke lokasi yang nyaman. Misalnya, di C: \ eclipse di Windows, atau / usr / local / eclipse di Linux / Unix dan terakhir atur variabel PATH dengan tepat.

Eclipse dapat dimulai dengan menjalankan perintah berikut di mesin Windows, atau Anda dapat mengklik dua kali pada eclipse.exe

%C:\eclipse\eclipse.exe

Eclipse dapat dimulai dengan menjalankan perintah berikut di mesin Unix (Solaris, Linux, dll.) -

$/usr/local/eclipse/eclipse

Setelah startup berhasil, jika semuanya baik-baik saja maka itu akan menampilkan hasil sebagai berikut -

Setelah Anda selesai dengan langkah terakhir ini, Anda siap untuk melanjutkan untuk contoh AOP pertama Anda, yang akan Anda lihat di bab berikutnya.

Sebelum kita mulai bekerja dengan AOP, marilah kita mengenal konsep dan terminologi AOP. Istilah ini tidak spesifik untuk Spring, melainkan terkait dengan AOP.

Sr.No. Syarat & Deskripsi
1

Aspect

Sebuah modul yang memiliki seperangkat API yang menyediakan persyaratan lintas sektoral. Misalnya, modul logging akan disebut aspek AOP untuk logging. Aplikasi dapat memiliki sejumlah aspek tergantung pada kebutuhan.

2

Join point

Ini mewakili titik dalam aplikasi Anda di mana Anda dapat memasukkan aspek AOP. Anda juga dapat mengatakan, ini adalah tempat sebenarnya dalam aplikasi tempat tindakan akan diambil menggunakan kerangka kerja Spring AOP.

3

Advice

Ini adalah tindakan aktual yang harus diambil sebelum atau sesudah eksekusi metode. Ini adalah bagian kode sebenarnya yang dipanggil selama eksekusi program oleh kerangka AOP Spring.

4

PointCut

Ini adalah satu set dari satu atau lebih titik penghubung di mana sebuah saran harus dijalankan. Anda dapat menentukan PointCuts menggunakan ekspresi atau pola seperti yang akan kita lihat di contoh AOP kita.

5

Introduction

Pengenalan memungkinkan Anda menambahkan metode atau atribut baru ke kelas yang ada.

6

Target object

Objek sedang dinasehati oleh satu atau lebih aspek. Objek ini akan selalu menjadi objek yang diproksikan. Juga disebut sebagai objek yang disarankan.

7

Weaving

Weaving adalah proses menghubungkan aspek dengan objek atau tipe aplikasi lain untuk membuat objek yang disarankan. Ini dapat dilakukan pada waktu kompilasi, waktu muat, atau saat runtime.

Aspek pegas dapat bekerja dengan lima jenis saran yang disebutkan dalam tabel berikut.

Sr.No. Saran & Deskripsi
1

before

Jalankan saran sebelum eksekusi metode.

2

after

Jalankan saran setelah eksekusi metode, apa pun hasilnya.

3

after-returning

Jalankan saran setelah eksekusi metode, hanya jika metode tersebut berhasil diselesaikan.

4

after-throwing

Jalankan saran setelah eksekusi metode, hanya jika metode keluar dengan menampilkan pengecualian.

5

around

Jalankan saran sebelum dan setelah metode yang disarankan dipanggil.

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(){
   ...
}

Pada bab ini, kita akan menulis aplikasi AOP yang sebenarnya menggunakan Kerangka AOP Spring. Sebelum Anda mulai menulis contoh pertama Anda menggunakan kerangka kerja Spring-WS, Anda harus memastikan bahwa Anda telah mengatur lingkungan Spring AOP dengan benar seperti yang dijelaskan dalam bab Spring Web Services - Environment Setup .

Sekarang, lanjutkan dengan menulis Aplikasi AOP Spring ased konsol, yang akan mendemonstrasikan konsep AOP.

Buat Proyek

Step 1 - Buka konsol perintah, buka direktori C: \ MVN dan jalankan perintah berikut mvn perintah.

C:\MVN>mvn archetype:generate -DgroupId = com.tutorialspoint -DartifactId = Student
	-DarchetypeArtifactId = maven-archetype-quickstart -DinteractiveMode = false

Maven akan mulai memproses dan membuat struktur proyek aplikasi Java yang lengkap.

[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building Maven Stub Project (No POM) 1
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] >>> maven-archetype-plugin:2.4:generate (default-cli) > generate-sources
@ standalone-pom >>>
[INFO]
[INFO] <<< maven-archetype-plugin:2.4:generate (default-cli) < generate-sources
@ standalone-pom <<<
[INFO]
[INFO] --- maven-archetype-plugin:2.4:generate (default-cli) @ standalone-pom --
-
[INFO] Generating project in Batch mode
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/archetypes/ma
ven-archetype-quickstart/1.0/maven-archetype-quickstart-1.0.jar
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/archetypes/mav
en-archetype-quickstart/1.0/maven-archetype-quickstart-1.0.jar (5 KB at 1.1 KB/s
ec)
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/archetypes/ma
ven-archetype-quickstart/1.0/maven-archetype-quickstart-1.0.pom
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/archetypes/mav
en-archetype-quickstart/1.0/maven-archetype-quickstart-1.0.pom (703 B at 1.2 KB/
sec)
[INFO] -------------------------------------------------------------------------
---
[INFO] Using following parameters for creating project from Old (1.x) Archetype:
 maven-archetype-quickstart:1.0
[INFO] -------------------------------------------------------------------------
---
[INFO] Parameter: groupId, Value: com.tutorialspoint
[INFO] Parameter: packageName, Value: com.tutorialspoint
[INFO] Parameter: package, Value: com.tutorialspoint
[INFO] Parameter: artifactId, Value: Student
[INFO] Parameter: basedir, Value: C:\MVN
[INFO] Parameter: version, Value: 1.0-SNAPSHOT
[INFO] project created from Old (1.x) Archetype in dir: C:\MVN\Student
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 01:17 min
[INFO] Finished at: 2017-02-19T21:11:14+05:30
[INFO] Final Memory: 15M/114M
[INFO] ------------------------------------------------------------------------

Step 2- Masuk ke direktori C: / MVN. Anda akan melihat proyek aplikasi Java dibuat, bernama siswa (sebagaimana ditentukan dalam artifactId). Perbarui POM.xml untuk menyertakan dependensi Spring-AOP. Tambahkan file MainApp.java, Student.java, dan Logging.java.

POM.xml

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/maven-v4_0_0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>Student</artifactId>
   <packaging>jar</packaging>
   <version>1.0-SNAPSHOT</version>
   <name>Student</name>
   <url>http://maven.apache.org</url>
   
   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-aop</artifactId>
         <version>4.1.0.RELEASE</version>
      </dependency>
      
      <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-context</artifactId>
         <version>4.1.4.RELEASE</version>
      </dependency>
      
      <dependency>
         <groupId>org.aspectj</groupId>
         <artifactId>aspectjweaver</artifactId>
         <version>1.6.8</version>
      </dependency>
      
   </dependencies>
</project>
package com.tutorialspoint;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   public void beforeAdvice() {
      System.out.println("Going to setup student profile.");
   }

   /** 
    * This is the method which I would like to execute
    * after a selected method execution.
    */
   public void afterAdvice() {
      System.out.println("Student profile has been setup.");
   }

   /** 
    * This is the method which I would like to execute
    * when any method returns.
    */
   public void afterReturningAdvice(Object retVal){
      System.out.println("Returning:" + retVal.toString() );
   }

   /**
    * This is the method which I would like to execute
    * if there is an exception raised.
    */
   public void AfterThrowingAdvice(IllegalArgumentException ex) {
      System.out.println("There has been an exception: " + ex.toString());   
   }
   
}

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.getName();
      student.getAge();
      
      student.printThrowException();
   }
}

Step 3 - Tambahkan file konfigurasi Beans.xml dibawah src > main > resources map.

<?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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
            expression = "execution(* com.tutorialspoint.*.*(..))"/>
         <aop:before PointCut-ref = "selectAll" method = "beforeAdvice"/>
         <aop:after PointCut-ref = "selectAll" method = "afterAdvice"/>
         <aop:after-returning PointCut-ref = "selectAll" 
            returning = "retVal"
            method = "afterReturningAdvice"/>
         <aop:after-throwing PointCut-ref = "selectAll" 
           throwing = "ex"
            method = "AfterThrowingAdvice"/>
      </aop:aspect>
   </aop:config>

   <!-- 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>

Step 4 - Buka konsol perintah, buka direktori C: \ MVN dan jalankan perintah berikut mvn perintah.

C:\MVN>Student> mvn package

Maven akan mulai memproses dan mengunduh pustaka yang diperlukan.

[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building Student 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven
-jar-plugin/2.4/maven-jar-plugin-2.4.pom
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven-
jar-plugin/2.4/maven-jar-plugin-2.4.pom (6 KB at 2.2 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven
-jar-plugin/2.4/maven-jar-plugin-2.4.jar
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven-
jar-plugin/2.4/maven-jar-plugin-2.4.jar (34 KB at 31.6 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-aop
/4.1.0.RELEASE/spring-aop-4.1.0.RELEASE.pom
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-aop/
4.1.0.RELEASE/spring-aop-4.1.0.RELEASE.pom (3 KB at 3.7 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-bea
ns/4.1.0.RELEASE/spring-beans-4.1.0.RELEASE.pom
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-bean
s/4.1.0.RELEASE/spring-beans-4.1.0.RELEASE.pom (3 KB at 4.1 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-cor
e/4.1.0.RELEASE/spring-core-4.1.0.RELEASE.pom
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-core
/4.1.0.RELEASE/spring-core-4.1.0.RELEASE.pom (3 KB at 4.0 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-aop
/4.1.0.RELEASE/spring-aop-4.1.0.RELEASE.jar
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-cor
e/4.1.0.RELEASE/spring-core-4.1.0.RELEASE.jar
Downloading: https://repo.maven.apache.org/maven2/org/springframework/spring-bea
ns/4.1.0.RELEASE/spring-beans-4.1.0.RELEASE.jar
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-aop/
4.1.0.RELEASE/spring-aop-4.1.0.RELEASE.jar (351 KB at 43.9 KB/sec)
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-bean
s/4.1.0.RELEASE/spring-beans-4.1.0.RELEASE.jar (685 KB at 37.5 KB/sec)
Downloaded: https://repo.maven.apache.org/maven2/org/springframework/spring-core
/4.1.0.RELEASE/spring-core-4.1.0.RELEASE.jar (982 KB at 47.1 KB/sec)
[INFO]
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ Student --
-
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory C:\MVN\Student\src\main\resources
[INFO]
[INFO] --- maven-compiler-plugin:3.1:compile (default-compile) @ Student ---
[INFO] Changes detected - recompiling the module!
[WARNING] File encoding has not been set, using platform encoding Cp1252, i.e. b
uild is platform dependent!
[INFO] Compiling 1 source file to C:\MVN\Student\target\classes
[INFO]
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ St
udent ---
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory C:\MVN\Student\src\test\resources
[INFO]
[INFO] --- maven-compiler-plugin:3.1:testCompile (default-testCompile) @ Student
 ---
[INFO] Changes detected - recompiling the module!
[WARNING] File encoding has not been set, using platform encoding Cp1252, i.e. b
uild is platform dependent!
[INFO] Compiling 1 source file to C:\MVN\Student\target\test-classes
[INFO]
[INFO] --- maven-surefire-plugin:2.12.4:test (default-test) @ Student ---
[INFO] Surefire report directory: C:\MVN\Student\target\surefire-reports
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/surefire/sure
fire-junit3/2.12.4/surefire-junit3-2.12.4.pom
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/surefire/suref
ire-junit3/2.12.4/surefire-junit3-2.12.4.pom (2 KB at 1.3 KB/sec)
Downloading: https://repo.maven.apache.org/maven2/org/apache/maven/surefire/sure
fire-junit3/2.12.4/surefire-junit3-2.12.4.jar
Downloaded: https://repo.maven.apache.org/maven2/org/apache/maven/surefire/suref
ire-junit3/2.12.4/surefire-junit3-2.12.4.jar (26 KB at 27.7 KB/sec)

-------------------------------------------------------
 T E S T S
-------------------------------------------------------
Running com.tutorialspoint.AppTest
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.002 sec

Results :

Tests run: 1, Failures: 0, Errors: 0, Skipped: 0

[INFO]
[INFO] --- maven-jar-plugin:2.4:jar (default-jar) @ Student ---
Downloading: https://repo.maven.apache.org/maven2/classworlds/classworlds/1.1-al
pha-2/classworlds-1.1-alpha-2.jar
Downloaded: https://repo.maven.apache.org/maven2/classworlds/classworlds/1.1-alp
ha-2/classworlds-1.1-alpha-2.jar (37 KB at 35.8 KB/sec)
[INFO] Building jar: C:\MVN\Student\target\Student-1.0-SNAPSHOT.jar
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 38.441 s
[INFO] Finished at: 2017-02-19T21:18:59+05:30
[INFO] Final Memory: 18M/109M
[INFO] ------------------------------------------------------------------------

Impor Proyek di Eclipse

Step 1 - Buka Eclipse.

Step 2 - Pilih File → Import → pilihan.

Step 3- Pilih Opsi Proyek Maven. Klik Tombol Berikutnya.

Step 4 - Pilih lokasi Proyek, di mana proyek Siswa dibuat menggunakan Maven.

Step 5 - Klik Tombol Selesai.

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
Student profile has been setup.
Returning:Zara
Going to setup student profile.
Age : 11
Student profile has been setup.
Returning:11
Going to setup student profile.
Exception raised
Student profile has been setup.
There has been an 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.framework.adapter.MethodBeforeAdviceInterceptor.invoke(MethodBeforeAdviceInterceptor.java:52) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.aspectj.AspectJAfterAdvice.invoke(AspectJAfterAdvice.java:43) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.adapter.AfterReturningAdviceInterceptor.invoke(AfterReturningAdviceInterceptor.java:52) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) 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$$56a970f2.printThrowException(<generated>)
   
   at com.tutorialspoint.MainApp.main(MainApp.java:16)

Bergabunglah dengan Point

JoinPoint mewakili sebuah titik dalam aplikasi Anda di mana Anda dapat memasukkan aspek AOP. Anda juga dapat mengatakan, ini adalah tempat sebenarnya dalam aplikasi tempat tindakan akan diambil menggunakan kerangka kerja Spring AOP. Pertimbangkan contoh berikut -

  • Semua kelas metode yang terdapat dalam sebuah paket.

  • Metode kelas tertentu.

PointCut

PointCut adalah sekumpulan satu atau lebih JoinPoints di mana saran harus dijalankan. Anda dapat menentukan PointCuts menggunakan ekspresi atau pola seperti yang akan kita lihat di contoh AOP kita. Di Musim Semi, PointCut membantu menggunakan JoinPoints tertentu untuk menerapkan saran. Pertimbangkan contoh berikut -

  • ekspresi = "eksekusi (* com.tutorialspoint. *. * (..))"

  • ekspresi = "eksekusi (* com.tutorialspoint.Student.getName (..))"

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "adviceClass">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
   </aop:aspect>
</aop:config>

Dimana,

  • adviceClass - ref kelas yang berisi metode saran

  • PointCut-id - id dari PointCut

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

Untuk memahami konsep yang disebutkan di atas terkait dengan JoinPoint dan PointCut, mari kita tulis sebuah contoh yang akan mengimplementasikan beberapa PointCuts. 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;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }   
}

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.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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
         expression = "execution(* com.tutorialspoint.*.*(..))"/>
         <aop:before PointCut-ref = "selectAll" method = "beforeAdvice"/>         
      </aop:aspect>
   </aop:config>

   <!-- 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>

Setelah Anda selesai membuat file konfigurasi source dan bean, jalankan aplikasi. Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan mencetak pesan berikut.

Going to setup student profile.
Name : Zara
Going to setup student profile.
Age : 11

<Aop: pointcut> yang didefinisikan di atas memilih semua metode yang ditentukan di bawah paket com.tutorialspoint. Misalkan, Anda ingin menjalankan saran Anda sebelum atau sesudah metode tertentu, Anda dapat menentukan PointCut Anda untuk mempersempit eksekusi Anda dengan mengganti bintang (*) dalam definisi PointCut dengan kelas aktual dan nama metode. Berikut ini adalah file konfigurasi XML yang dimodifikasi untuk menunjukkan konsep tersebut.

<?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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
            expression = "execution(* com.tutorialspoint.Student.getName(..))"/>
         <aop:before PointCut-ref = "selectAll" method = "beforeAdvice"/>
      </aop:aspect>
   </aop:config>

   <!-- 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

Beforeadalah jenis saran yang memastikan bahwa saran berjalan sebelum eksekusi metode. Berikut ini adalah sintaks sebelum saran.

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "logging">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
      <aop:before PointCut-ref = "PointCut-id" method = "methodName"/>
   </aop:aspect>
</aop:config>

Dimana,

  • PointCut-id - id dari PointCut.

  • methodName - Nama metode dari fungsi yang akan dipanggil sebelum fungsi yang dipanggil.

Untuk memahami konsep yang disebutkan di atas terkait dengan Before Advice, mari kita tulis sebuah 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;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }   
}

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.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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
            expression = "execution(* com.tutorialspoint.Student.getName(..))"/>
         <aop:before PointCut-ref = "selectAll" method = "beforeAdvice"/>
      </aop:aspect>
   </aop:config>

   <!-- 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

Afteradalah jenis saran yang memastikan bahwa saran berjalan setelah eksekusi metode. Berikut ini adalah sintaks saran setelah.

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "logging">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
      <aop:after PointCut-ref = "PointCut-id" method = "methodName"/>
   </aop:aspect>
</aop:config>

Dimana,

  • PointCut-id - id dari PointCut.

  • methodName - Nama metode dari fungsi yang akan dipanggil setelah fungsi yang dipanggil.

Untuk memahami konsep yang disebutkan di atas terkait dengan After Advice, mari kita tulis sebuah contoh yang akan mengimplementasikan After 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;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * after a selected method execution.
    */
   public void afterAdvice(){
      System.out.println("Student profile setup complete.");
   }   
}

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.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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
            expression = "execution(* com.tutorialspoint.Student.getAge(..))"/>
         <aop:after PointCut-ref = "selectAll" method = "afterAdvice"/>
      </aop:aspect>
   </aop:config>

   <!-- 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, ini akan mencetak pesan berikut.

Name : Zara
Age : 11
Student profile setup complete.

Afteradalah jenis saran yang memastikan bahwa saran berjalan setelah eksekusi metode hanya jika metode tersebut berhasil diselesaikan. Berikut ini adalah sintaks saran setelah.

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "logging">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
      <aop:after-returning PointCut-ref = "PointCut-id" 
         returning = "retVal" method = "methodName"/>
   </aop:aspect>
</aop:config>

Dimana,

  • PointCut-id - id dari PointCut.

  • methodName - Nama metode dari fungsi yang akan dipanggil setelah fungsi yang dipanggil kembali dengan sukses.

Untuk memahami konsep yang disebutkan di atas terkait dengan Saran Setelah Kembali, mari kita tulis sebuah contoh yang akan menerapkan saran Setelah Pengembalian. 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;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * when any method returns.
    */
   public void afterReturningAdvice(Object retVal){
      System.out.println("Returning:" + retVal.toString() );
   }
}

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 );
      System.out.println("Exception raised");
      throw new IllegalArgumentException();
      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.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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
         expression = "execution(* com.tutorialspoint.*.*(..))"/>
         <aop:after-returning PointCut-ref = "selectAll" 
            method = "afterReturningAdvice" returning = "retVal"/>         
      </aop:aspect>
   </aop:config>

   <!-- 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.

Name : Zara
Returning : Name
Age : 11
Exception raised

After-throwingadalah jenis saran yang memastikan bahwa saran berjalan setelah eksekusi metode, hanya jika metode keluar dengan menampilkan pengecualian. Berikut ini adalah sintaks saran setelah melempar.

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "logging">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
      <aop:after-throwing PointCut-ref = "PointCut-id" throwing = "ex" 
         method = "methodName"/>
   </aop:aspect>
</aop:config>

Dimana,

  • PointCut-id - id dari PointCut.

  • ex - Pengecualian untuk dilempar.

  • methodName - Nama metode dari fungsi yang akan dipanggil saat fungsi yang dipanggil melontarkan pengecualian dan keluar.

Untuk memahami konsep yang disebutkan di atas terkait dengan Saran Setelah Melempar, mari kita tulis sebuah contoh yang akan menerapkan Saran Setelah Melempar. 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;

public class Logging {
   /**
    * This is the method which I would like to execute
    * if there is an exception raised.
    */
   public void afterThrowingAdvice(IllegalArgumentException ex) {
      System.out.println("There has been an exception: " + ex.toString());   
   } 
}

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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectAll" 
         expression = "execution(* com.tutorialspoint.*.*(..))"/>
         <aop:after-throwing PointCut-ref = "selectAll" 
            throwing = "ex" method = "afterThrowingAdvice"/>         
      </aop:aspect>
   </aop:config>

   <!-- 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
There has been an 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$$8514cd8.printThrowException(<generated>)
	
   at com.tutorialspoint.MainApp.main(MainApp.java:15)

Aroundadalah jenis saran yang memastikan bahwa saran berjalan sebelum dan sesudah eksekusi metode. Berikut ini adalah sintaks sekitar nasihat.

Sintaksis

<aop:config>
   <aop:aspect id = "log" ref = "logging">
      <aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>    
      <aop:around PointCut-ref = "PointCut-id" method = "methodName"/>
   </aop:aspect>
</aop:config>

Dimana,

  • PointCut-id - id dari PointCut.

  • methodName - Nama metode dari fungsi yang akan dipanggil sebelum fungsi yang dipanggil.

Untuk memahami konsep yang disebutkan di atas terkait dengan Around Advice, mari kita tulis sebuah contoh yang akan mengimplementasikan Around 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.ProceedingJoinPoint;

public class Logging {

   /** 
    * This is the method which I would like to execute
    * around a selected method execution.
    */
   public String aroundAdvice(ProceedingJoinPoint jp) throws Throwable{
      System.out.println("Around advice");
      Object[] args = jp.getArgs();
      if(args.length>0){
         System.out.print("Arguments passed: " );
         for (int i = 0; i < args.length; i++) {
            System.out.print("arg "+(i+1)+": "+args[i]);
         }
      }

      Object result = jp.proceed(args);
      System.out.println("Returning " + result);
      return result.toString();
   }   
}

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.getName();    
   }
}

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:config>
      <aop:aspect id = "log" ref = "logging">
         <aop:PointCut id = "selectName" 
            expression = "execution(* com.tutorialspoint.Student.getName(..))"/>
         <aop:around PointCut-ref = "selectName" method = "aroundAdvice"/>
      </aop:aspect>
   </aop:config>

   <!-- 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.

Around advice
Name : Zara
Returning Zara

Mari kita tulis contoh yang akan mengimplementasikan saran menggunakan konfigurasi berbasis Anotasi. Untuk ini, mari kita memiliki IDE Eclipse yang berfungsi dan menggunakan 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;
import org.aspectj.lang.annotation.PointCut;

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.*.*(..))")
   private void selectAll(){}

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   @Before("selectAll()")
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }  
}

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.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
Going to setup student profile.
Age : 11

JoinPoint

JoinPoint mewakili sebuah titik dalam aplikasi Anda di mana Anda dapat memasukkan aspek AOP. Anda juga dapat mengatakan, ini adalah tempat sebenarnya dalam aplikasi tempat tindakan akan diambil menggunakan kerangka kerja Spring AOP. Pertimbangkan contoh berikut -

  • Semua kelas metode yang terdapat dalam sebuah paket.

  • Metode kelas tertentu.

PointCut

PointCut adalah satu set dari satu atau lebih JoinPoint di mana sebuah saran harus dijalankan. Anda dapat menentukan PointCuts menggunakan ekspresi atau pola seperti yang akan kita lihat di contoh AOP kita. Di Musim Semi, PointCut membantu menggunakan JoinPoints tertentu untuk menerapkan saran. Pertimbangkan contoh berikut -

  • @PointCut ("eksekusi (* com.tutorialspoint. *. * (..))")

  • @PointCut ("eksekusi (* com.tutorialspoint.Student.getName (..))")

Sintaksis

@Aspect
public class Logging {

   @PointCut("execution(* com.tutorialspoint.*.*(..))")
   private void selectAll(){}

}

Dimana,

  • @Aspect - Menandai kelas sebagai kelas yang berisi metode saran.

  • @PointCut - Tandai fungsi sebagai PointCut

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

Untuk memahami konsep yang disebutkan di atas terkait dengan JoinPoint dan PointCut, mari kita tulis sebuah contoh yang akan mengimplementasikan beberapa PointCuts. 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.PointCut;
import org.aspectj.lang.annotation.Before;

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.*.*(..))")
   private void selectAll(){}

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   @Before("selectAll()")
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }  
}

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.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
Going to setup student profile.
Age : 11

@Pointcut yang ditentukan di atas menggunakan ekspresi untuk memilih semua metode yang ditentukan di bawah paket com.tutorialspoint. @Before saran menggunakan PointCut yang didefinisikan di atas sebagai parameter. Secara efektif metode beforeAdvice () akan dipanggil sebelum setiap metode yang dicakup oleh PointCut di atas.

@Beforeadalah jenis saran yang memastikan bahwa saran berjalan sebelum eksekusi metode. Berikut adalah sintaks dari saran @Before.

Sintaksis

@PointCut("execution(* com.tutorialspoint.Student.getName(..))")
private void selectGetName(){}

@Before("selectGetName()")
public void beforeAdvice(){
   System.out.println("Going to setup student profile.");
}

Dimana,

  • @PointCut - Tandai fungsi sebagai PointCut

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

  • @Before - Tandai fungsi sebagai saran untuk dieksekusi sebelum metode yang dicakup oleh PointCut.

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.PointCut;
import org.aspectj.lang.annotation.Before;

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.Student.getName(..))")
   private void selectGetName(){}

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   @Before("selectGetName()")
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }  
}

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.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

@Pointcut yang ditentukan di atas menggunakan ekspresi untuk memilih metode getAge () yang ditentukan di kelas (es) di bawah paket com.tutorialspoint. @Setelah saran menggunakan PointCut yang ditentukan di atas sebagai parameter. Secara efektif, metode afterAdvice () akan dipanggil sebelum setiap metode yang dicakup oleh PointCut di atas.

@Afteradalah jenis saran yang memastikan bahwa saran berjalan setelah eksekusi metode. Berikut adalah sintaks saran @After.

Sintaksis

@PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
private void selectGetName(){}

@After("selectGetAge()")
public void afterAdvice(){
   System.out.println("Student profile setup completed.");
}

Dimana,

  • @PointCut - Tandai fungsi sebagai PointCut

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

  • @After - Tandai fungsi sebagai saran untuk dieksekusi sebelum metode yang dicakup oleh PointCut.

Untuk memahami konsep yang disebutkan di atas terkait dengan @After Advice, mari kita tulis sebuah contoh yang akan mengimplementasikan @After 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.PointCut;
import org.aspectj.lang.annotation.After;

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
   private void selectGetAge(){}

   /** 
    * This is the method which I would like to execute
    * after a selected method execution.
    */
   @After("selectGetAge()")
   public void afterAdvice(){
      System.out.println("Student profile setup completed.");
   }  
}

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.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.

Name : Zara
Age : 11
Student profile setup completed.

@Pointcut yang ditentukan di atas menggunakan ekspresi untuk memilih metode getAge () yang ditentukan di kelas (es) di bawah paket com.tutorialspoint. @Setelah saran menggunakan PointCut yang ditentukan di atas sebagai parameter. Secara efektif, metode afterAdvice () akan dipanggil sebelum setiap metode yang dicakup oleh PointCut di atas.

@AfterReturningadalah tipe saran, yang memastikan bahwa saran berjalan setelah metode berhasil dijalankan. Berikut adalah sintaks dari saran @AfterReturning.

Sintaksis

@AfterReturning(PointCut = "execution(* com.tutorialspoint.Student.*(..))", 
   returning = "retVal")
public void afterReturningAdvice(JoinPoint jp, Object retVal){
   System.out.println("Method Signature: "  + jp.getSignature());  
   System.out.println("Returning:" + retVal.toString() );
}

Dimana,

  • @AfterReturning - Tandai fungsi sebagai saran untuk dieksekusi sebelum metode yang dicakup oleh PointCut, jika metode berhasil kembali.

  • PointCut - Memberikan ekspresi untuk memilih fungsi

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

  • returning - Nama variabel yang akan dikembalikan.

Untuk memahami konsep yang disebutkan di atas terkait dengan Saran @AfterReturning, mari kita tulis sebuah contoh, yang akan mengimplementasikan Saran @AfterReturning. 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.AfterReturning; 

@Aspect
public class Logging {

   /** 
    * This is the method which I would like to execute
    * after a selected method execution.
    */
   @AfterReturning(PointCut = "execution(* com.tutorialspoint.Student.*(..))", 
      returning = "retVal")
   public void afterReturningAdvice(JoinPoint jp, Object retVal){
      System.out.println("Method Signature: "  + jp.getSignature());  
      System.out.println("Returning:" + retVal.toString() );
   }
}

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.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.

Age : 11
Method Signature: Integer com.tutorialspoint.Student.getAge()  
Returning 11

@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 - Menandai 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)

@Aroundadalah jenis saran, yang memastikan bahwa saran dapat dijalankan sebelum dan sesudah eksekusi metode. Berikut ini adalah sintaks saran @Around.

Sintaksis

@PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
private void selectGetName(){}

@Around("selectGetAge()")
public void aroundAdvice(ProceedingJoinPoint proceedingJoinPoint){
   System.out.println("Around advice");
   Object[] args = jp.getArgs();
   if(args.length>0){
      System.out.print("Arguments passed: " );
      for (int i = 0; i < args.length; i++) {
         System.out.print("arg "+(i+1)+": "+args[i]);
      }
   }

   Object result = jp.proceed(args);
   System.out.println("Returning " + result);
   return result.toString();   
}

Dimana,

  • @PointCut - Tandai fungsi sebagai PointCut

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

  • @Around - Tandai fungsi sebagai saran untuk dieksekusi sebelum metode yang dicakup oleh PointCut.

Untuk memahami konsep yang disebutkan di atas terkait dengan @Around Advice, mari kita tulis contoh yang akan mengimplementasikan Saran @Around. 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.PointCut;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.ProceedingJoinPoint; 

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
   private void selectGetAge(){}

   /** 
    * This is the method which I would like to execute
    * around a selected method execution.
    */
   @Around("selectGetAge()")
   public void aroundAdvice(ProceedingJoinPoint proceedingJoinPoint) throws Throwable{
      System.out.println("Around advice");
      Object[] args = proceedingJoinPoint.getArgs();
      if(args.length>0){
         System.out.print("Arguments passed: " );
         for (int i = 0; i < args.length; i++) {
            System.out.print("arg "+(i+1)+": "+args[i]);
         }
      }

      Object result = proceedingJoinPoint.proceed(args);
      System.out.println("Returning " + result);
   }  
}

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.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.

Around advice
Age : 11
Returning 11

Sejauh ini, kami telah mendeklarasikan aspek menggunakan <aop:config> atau < aop:aspectj-autoproxy>. Kita dapat membuat proxy secara terprogram serta menjalankan aspek secara terprogram menggunakan objek proxy.

Sintaksis

//Create object to be proxied
Student student = new Student();

//Create the Proxy Factory
AspectJProxyFactory proxyFactory = new AspectJProxyFactory(student);

//Add Aspect class to the factory
proxyFactory.addAspect(Logging.class);

//Get the proxy object
Student proxyStudent = proxyFactory.getProxy();

//Invoke the proxied method.
proxyStudent.getAge();

Dimana,

  • AspectJProxyFactory - Kelas pabrik untuk membuat objek proxy.

  • Logging.class - Kelas Aspek yang berisi nasihat.

  • Student - Kelas bisnis untuk dinasihati.

Untuk memahami konsep yang disebutkan di atas terkait dengan proxy, mari kita tulis sebuah contoh yang akan mengimplementasikan proxy. 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.PointCut;
import org.aspectj.lang.annotation.Before;

@Aspect
public class Logging {

   /** Following is the definition for a PointCut to select
    *  all the methods available. So advice will be called
    *  for all the methods.
    */
   @PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
   private void selectGetAge(){}

   /** 
    * This is the method which I would like to execute
    * before a selected method execution.
    */
   @Before("selectGetAge()")
   public void beforeAdvice(){
      System.out.println("Going to setup student profile.");
   }  
}

Berikut ini adalah konten dari Student.java mengajukan.

package com.tutorialspoint;

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

Berikut ini adalah konten dari MainApp.java mengajukan.

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.aop.aspectj.annotation.AspectJProxyFactory;

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

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

      //Create the Proxy Factory
      AspectJProxyFactory proxyFactory = new AspectJProxyFactory(student);

      //Add Aspect class to the factory
      proxyFactory.addAspect(Logging.class);

      //Get the proxy object
      Student proxyStudent = proxyFactory.getProxy();

      //Invoke the proxied method.
      proxyStudent.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 ">

   <!-- Definition for student bean -->
   <bean id = "student" class = "com.tutorialspoint.Student">
      <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.
Age : 11

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