Spring AOP - คู่มือฉบับย่อ

องค์ประกอบสำคัญอย่างหนึ่งของ Spring Framework คือไฟล์ Aspect Oriented Programming (AOP)กรอบ. Aspect Oriented Programming นำเสนอการแยกตรรกะของโปรแกรมออกเป็นส่วนต่างๆที่เรียกว่าso-called concerns. ฟังก์ชันที่ครอบคลุมหลายจุดของแอปพลิเคชันเรียกว่าข้อกังวลข้าม เหล่านี้cross-cutting concernsแนวคิดแยกจากตรรกะทางธุรกิจของแอปพลิเคชัน มีตัวอย่างด้านต่างๆที่ดีเช่นการบันทึกการตรวจสอบธุรกรรมที่เปิดเผยการรักษาความปลอดภัยการแคชเป็นต้น

หน่วยหลักของโมดูลาร์ใน OOP คือคลาสในขณะที่ใน AOP หน่วยของโมดูลาร์คือด้าน Dependency Injection ช่วยให้คุณแยกวัตถุแอปพลิเคชันของคุณออกจากกันในขณะที่ AOP ช่วยให้คุณแยกข้อกังวลข้ามการตัดออกจากวัตถุที่ส่งผลกระทบ AOP เป็นเหมือนทริกเกอร์ในภาษาโปรแกรมเช่น Perl, .NET, Java และอื่น ๆ

โมดูล Spring AOP ช่วยให้ตัวสกัดกั้นสกัดกั้นแอปพลิเคชัน ตัวอย่างเช่นเมื่อเรียกใช้เมธอดคุณสามารถเพิ่มฟังก์ชันพิเศษก่อนหรือหลังการเรียกใช้เมธอดได้

บทนี้จะนำคุณผ่านขั้นตอนการตั้งค่า Spring AOP บนระบบที่ใช้ Windows และ Linux Spring AOP สามารถติดตั้งและรวมเข้ากับสภาพแวดล้อม Java และ MAVEN ปัจจุบันของคุณได้อย่างง่ายดายโดยทำตามขั้นตอนง่ายๆไม่กี่ขั้นตอนโดยไม่ต้องมีขั้นตอนการตั้งค่าที่ซับซ้อน จำเป็นต้องมีการดูแลระบบผู้ใช้ขณะติดตั้ง

ความต้องการของระบบ

JDK Java SE 2 JDK 1.5 ขึ้นไป
หน่วยความจำ RAM 1 GB (แนะนำ)
พื้นที่ดิสก์ ไม่มีข้อกำหนดขั้นต่ำ
เวอร์ชันระบบปฏิบัติการ Windows XP ขึ้นไปลินุกซ์

ตอนนี้ให้เราดูขั้นตอนในการติดตั้ง Spring AOP

ขั้นตอนที่ 1: ตรวจสอบการติดตั้ง Java ของคุณ

ก่อนอื่นคุณต้องติดตั้ง Java Software Development Kit (SDK) ในระบบของคุณ ในการตรวจสอบสิ่งนี้ให้ดำเนินการสองคำสั่งต่อไปนี้ขึ้นอยู่กับแพลตฟอร์มที่คุณกำลังทำงานอยู่

หากการติดตั้ง Java ทำได้อย่างถูกต้องการติดตั้งจะแสดงเวอร์ชันปัจจุบันและข้อมูลจำเพาะของการติดตั้ง Java ของคุณ ตัวอย่างผลลัพธ์จะได้รับในตารางต่อไปนี้

แพลตฟอร์ม คำสั่ง ตัวอย่างผลลัพธ์
Windows

เปิดคอนโซลคำสั่งและพิมพ์ -

\>java -version

เวอร์ชัน Java "1.7.0_60"

Java (TM) SE Run Time Environment (บิวด์ 1.7.0_60-b19)

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

ลินุกซ์

เปิดเทอร์มินัลคำสั่งแล้วพิมพ์ -

$java -version

เวอร์ชัน java "1.7.0_25"

เปิด JDK Runtime Environment (rhel-2.3.10.4.el6_4-x86_64)

เปิด JDK 64-Bit Server VM (สร้าง 23.7-b01 โหมดผสม)

เราถือว่าผู้อ่านบทช่วยสอนนี้ติดตั้ง Java SDK เวอร์ชัน 1.7.0_60 ในระบบของตน

ในกรณีที่คุณไม่มี Java SDK ให้ดาวน์โหลดเวอร์ชันปัจจุบันจากไฟล์ https://www.oracle.com/technetwork/java/javase/downloads/index.html และติดตั้ง

ขั้นตอนที่ 2: ตั้งค่าสภาพแวดล้อม Java ของคุณ

ตั้งค่าตัวแปรสภาพแวดล้อม JAVA_HOME ให้ชี้ไปยังตำแหน่งไดเร็กทอรีฐานที่ติดตั้ง Java บนเครื่องของคุณ ตัวอย่างเช่น,

ซีเนียร์ แพลตฟอร์มและคำอธิบาย
1

Windows

ตั้งค่า JAVA_HOME เป็น C: \ ProgramFiles \ java \ jdk1.7.0_60

2

Linux

ส่งออก JAVA_HOME = / usr / local / java-current

ผนวกพา ธ แบบเต็มของตำแหน่งคอมไพเลอร์ Java เข้ากับ System Path

ซีเนียร์ แพลตฟอร์มและคำอธิบาย
1

Windows

ต่อท้ายสตริง "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" ต่อท้ายพา ธ ตัวแปรระบบ

2

Linux

ส่งออกเส้นทาง = $ PATH: $ JAVA_HOME / bin /

ดำเนินการคำสั่ง java -version จากพรอมต์คำสั่งตามที่อธิบายไว้ข้างต้น

ขั้นตอนที่ 3: ดาวน์โหลด Maven Archive

ดาวน์โหลด Maven 3.3.3 จาก https://maven.apache.org/download.cgi

ระบบปฏิบัติการ ชื่อที่เก็บถาวร
Windows apache-maven-3.3.3-bin.zip
ลินุกซ์ apache-maven-3.3.3-bin.tar.gz
Mac apache-maven-3.3.3-bin.tar.gz

ขั้นตอนที่ 4: แตกไฟล์ Maven Archive

แตกไฟล์เก็บถาวรไปยังไดเร็กทอรีที่คุณต้องการติดตั้ง Maven 3.3.3 ไดเร็กทอรีย่อย apache-maven-3.3.3 จะถูกสร้างขึ้นจากไฟล์เก็บถาวร

ระบบปฏิบัติการ ตำแหน่ง (อาจแตกต่างกันไปตามการติดตั้งของคุณ)
Windows C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3
ลินุกซ์ / usr / local / apache-maven
Mac / usr / local / apache-maven

ขั้นตอนที่ 5: ตั้งค่าตัวแปรสภาพแวดล้อม Maven

เพิ่ม M2_HOME, M2, MAVEN_OPTS ให้กับตัวแปรสภาพแวดล้อม

ระบบปฏิบัติการ เอาต์พุต
Windows

ตั้งค่าตัวแปรสภาพแวดล้อมโดยใช้คุณสมบัติของระบบ

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

M2 =% M2_HOME% \ bin

MAVEN_OPTS = -Xms256m -Xmx512m

ลินุกซ์ เปิดเทอร์มินัลคำสั่งและตั้งค่าตัวแปรสภาพแวดล้อม

ส่งออก M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3

ส่งออก M2 = $ M2_HOME / bin

ส่งออก MAVEN_OPTS = -Xms256m -Xmx512m

Mac

เปิดเทอร์มินัลคำสั่งและตั้งค่าตัวแปรสภาพแวดล้อม

ส่งออก M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3

ส่งออก M2 = $ M2_HOME / bin

ส่งออก MAVEN_OPTS = -Xms256m -Xmx512m

ขั้นตอนที่ 6: เพิ่ม Maven Bin Directory Location ไปยัง System Path

ต่อท้ายตัวแปร M2 เข้ากับ System Path

ระบบปฏิบัติการ เอาต์พุต
Windows ต่อท้ายสตริง% M2% ต่อท้ายตัวแปรระบบ Path
ลินุกซ์ เส้นทางการส่งออก = $ M2: $ PATH
Mac เส้นทางการส่งออก = $ M2: $ PATH

ขั้นตอนที่ 7: ตรวจสอบการติดตั้ง Maven

ตอนนี้เปิดคอนโซลและดำเนินการต่อไปนี้ mvn คำสั่ง

ระบบปฏิบัติการ งาน คำสั่ง
Windows เปิด Command Console c: \> mvn - รุ่น
ลินุกซ์ เปิด Command Terminal $ mvn - รุ่น
Mac เปิด Terminal เครื่อง: <joseph $ mvn --version

สุดท้ายตรวจสอบผลลัพธ์ของคำสั่งข้างต้นซึ่งควรเป็นดังนี้ -

ระบบปฏิบัติการ เอาต์พุต
Windows

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

บ้าน Maven: C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3

เวอร์ชัน Java: 1.7.0_75 ผู้จำหน่าย: Oracle Corporation

หน้าแรกของ Java: C: \ Program Files \ Java \ jdk1.7.0_75 \ jre

ภาษาเริ่มต้น: en_US การเข้ารหัสแพลตฟอร์ม: Cp1252

ลินุกซ์

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

บ้าน Maven: /usr/local/apache-maven/apache-maven-3.3.3

เวอร์ชัน Java: 1.7.0_75 ผู้จำหน่าย: Oracle Corporation

โฮม Java: /usr/local/java-current/jdk1.7.0_75/jre

Mac

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

บ้าน Maven: /usr/local/apache-maven/apache-maven-3.3.3

เวอร์ชัน Java: 1.7.0_75 ผู้จำหน่าย: Oracle Corporation

โฮม Java: /Library/Java/Home/jdk1.7.0_75/jre

ขั้นตอนที่ 8 - ตั้งค่า Eclipse IDE

ตัวอย่างทั้งหมดในบทช่วยสอนนี้เขียนขึ้นโดยใช้ Eclipse IDE ดังนั้นฉันขอแนะนำให้คุณติดตั้ง Eclipse เวอร์ชันล่าสุดในเครื่องของคุณ

ในการติดตั้ง Eclipse IDE ให้ดาวน์โหลดไบนารี Eclipse ล่าสุดจาก https://www.eclipse.org/downloads/. เมื่อคุณดาวน์โหลดการติดตั้งแล้วให้แกะการกระจายไบนารีในตำแหน่งที่สะดวก ตัวอย่างเช่นใน C: \ eclipse บน Windows หรือ / usr / local / eclipse บน Linux / Unix และสุดท้ายตั้งค่าตัวแปร PATH ให้เหมาะสม

Eclipse สามารถเริ่มต้นได้โดยดำเนินการคำสั่งต่อไปนี้บนเครื่อง Windows หรือคุณสามารถดับเบิลคลิกที่ eclipse.exe

%C:\eclipse\eclipse.exe

Eclipse สามารถเริ่มต้นได้โดยดำเนินการคำสั่งต่อไปนี้บนเครื่อง Unix (Solaris, Linux และอื่น ๆ ) -

$/usr/local/eclipse/eclipse

หลังจากเริ่มต้นสำเร็จหากทุกอย่างเรียบร้อยดีควรแสดงผลลัพธ์ต่อไปนี้ -

เมื่อคุณทำขั้นตอนสุดท้ายนี้เสร็จแล้วคุณก็พร้อมที่จะดำเนินการตามตัวอย่าง AOP แรกของคุณซึ่งคุณจะเห็นในบทถัดไป

ก่อนที่เราจะเริ่มทำงานกับ AOP ขอให้เราทำความคุ้นเคยกับแนวคิดและคำศัพท์ของ AOP ข้อกำหนดเหล่านี้ไม่เฉพาะเจาะจงสำหรับ Spring แต่เกี่ยวข้องกับ AOP

ซีเนียร์ เงื่อนไขและคำอธิบาย
1

Aspect

โมดูลที่มีชุด API ที่ให้ข้อกำหนดการตัดขวาง ตัวอย่างเช่นโมดูลการบันทึกจะถูกเรียกว่าด้าน AOP สำหรับการบันทึก แอปพลิเคชันสามารถมีหลายแง่มุมขึ้นอยู่กับความต้องการ

2

Join point

สิ่งนี้แสดงถึงจุดในแอปพลิเคชันของคุณที่คุณสามารถเสียบด้าน AOP ได้ คุณสามารถพูดได้ว่าเป็นสถานที่จริงในแอปพลิเคชันที่จะดำเนินการโดยใช้ Spring AOP framework

3

Advice

นี่คือการดำเนินการจริงที่ต้องดำเนินการก่อนหรือหลังการเรียกใช้เมธอด นี่คือส่วนของโค้ดจริงที่ถูกเรียกใช้ระหว่างการทำงานของโปรแกรมโดย Spring AOP framework

4

PointCut

นี่คือชุดของจุดเชื่อมต่ออย่างน้อยหนึ่งจุดที่คำแนะนำควรดำเนินการ คุณสามารถระบุ PointCuts โดยใช้นิพจน์หรือรูปแบบดังที่เราจะเห็นในตัวอย่าง AOP ของเรา

5

Introduction

บทนำช่วยให้คุณสามารถเพิ่มวิธีการหรือแอตทริบิวต์ใหม่ให้กับคลาสที่มีอยู่

6

Target object

วัตถุที่ได้รับคำแนะนำจากด้านใดด้านหนึ่งหรือมากกว่านั้น วัตถุนี้จะเป็นวัตถุพร็อกซีเสมอ เรียกอีกอย่างว่าวัตถุที่แนะนำ

7

Weaving

การทอผ้าเป็นกระบวนการเชื่อมโยงด้านต่างๆกับประเภทแอปพลิเคชันหรือวัตถุอื่น ๆ เพื่อสร้างวัตถุที่แนะนำ ซึ่งสามารถทำได้ในเวลาคอมไพล์เวลาโหลดหรือรันไทม์

แง่มุมของสปริงสามารถใช้ได้กับคำแนะนำห้าประเภทที่กล่าวถึงในตารางต่อไปนี้

ซีเนียร์ คำแนะนำและคำอธิบาย
1

before

เรียกใช้คำแนะนำก่อนดำเนินการตามวิธีการ

2

after

เรียกใช้คำแนะนำหลังจากดำเนินการตามวิธีการโดยไม่คำนึงถึงผลลัพธ์

3

after-returning

เรียกใช้คำแนะนำหลังจากการเรียกใช้เมธอดเฉพาะเมื่อวิธีการดำเนินการสำเร็จ

4

after-throwing

เรียกใช้คำแนะนำหลังจากการเรียกใช้เมธอดเฉพาะในกรณีที่เมธอดนั้นออกโดยการทิ้งข้อยกเว้น

5

around

เรียกใช้คำแนะนำก่อนและหลังเรียกใช้วิธีการที่แนะนำ

สปริงรองรับ @AspectJ annotation style แนวทางและ schema-based แนวทางในการใช้แง่มุมที่กำหนดเอง

ตาม XML Schema

แง่มุมถูกนำไปใช้โดยใช้คลาสปกติพร้อมกับการกำหนดค่าตาม XML

ในการใช้แท็กเนมสเปซ AOP ที่อธิบายในส่วนนี้คุณต้องนำเข้าสคีมา AOP แบบสปริงซึ่งอธิบายไว้ดังต่อไปนี้ -

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

การประกาศมุมมอง

อัน aspect ถูกประกาศโดยใช้ <aop:aspect> องค์ประกอบและ backing bean อ้างอิงโดยใช้ ref แอตทริบิวต์ดังนี้

<aop:config>
   <aop:aspect id = "myAspect" ref = "aBean">
   ...
   </aop:aspect>
</aop:config>

<bean id = "aBean" class = "...">
   ...
</bean>

ที่นี่ "aBean" จะได้รับการกำหนดค่าและการพึ่งพาการฉีดเช่นเดียวกับ Spring bean อื่น ๆ ตามที่คุณเห็นในบทก่อน ๆ

การประกาศ PointCut

PointCutช่วยในการกำหนดจุดเข้าร่วม (เช่นวิธีการ) ที่น่าสนใจที่จะดำเนินการด้วยคำแนะนำที่แตกต่างกัน ในขณะที่ทำงานกับการกำหนดค่าตาม XML Schema PointCut จะถูกกำหนดดังนี้ -

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

ตัวอย่างต่อไปนี้กำหนด PointCut ชื่อ 'businessService' ที่จะจับคู่การดำเนินการของเมธอด getName () ที่มีอยู่ในคลาสนักเรียนภายใต้แพ็คเกจ 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>

การประกาศคำแนะนำ

คุณสามารถประกาศคำแนะนำใด ๆ จากห้าคำแนะนำภายใน <aop: ด้าน> โดยใช้องค์ประกอบ <aop: {ADVICE NAME}> ดังนี้

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

คุณสามารถใช้เช่นเดียวกัน doRequiredTaskหรือวิธีการต่างๆสำหรับคำแนะนำต่างๆ วิธีการเหล่านี้จะถูกกำหนดให้เป็นส่วนหนึ่งของโมดูลด้าน

@AspectJ อิง

@AspectJ หมายถึงรูปแบบของการประกาศแง่มุมเป็นคลาส Java ปกติที่มีคำอธิบายประกอบ Java 5 การสนับสนุน @AspectJ เปิดใช้งานโดยการรวมองค์ประกอบต่อไปนี้ไว้ในไฟล์คอนฟิกูเรชันตาม XML Schema ของคุณ

<aop:aspectj-autoproxy/>

การประกาศมุมมอง

คลาส Aspects ก็เหมือนกับ bean ทั่วไปทั่วไปและอาจมีเมธอดและฟิลด์เหมือนกับคลาสอื่น ๆ ยกเว้นว่าจะมีการใส่คำอธิบายประกอบด้วย @Aspect ดังนี้

package org.xyz;

import org.aspectj.lang.annotation.Aspect;

@Aspect
public class AspectModule {

}

พวกเขาจะถูกกำหนดค่าใน XML เหมือนกับ bean อื่น ๆ ดังต่อไปนี้

<bean id = "myAspect" class = "org.xyz.AspectModule">
   <!-- configure properties of aspect here as normal -->
</bean>

การประกาศ PointCut

PointCutช่วยในการกำหนดจุดเข้าร่วม (เช่นวิธีการ) ที่น่าสนใจที่จะดำเนินการด้วยคำแนะนำที่แตกต่างกัน ในขณะที่ทำงานกับการกำหนดค่าตาม @AspectJ การประกาศ PointCut มีสองส่วน -

  • นิพจน์ PointCut ที่กำหนดวิธีการดำเนินการที่เราสนใจ

  • ลายเซ็น PointCut ประกอบด้วยชื่อและพารามิเตอร์จำนวนเท่าใดก็ได้ เนื้อหาที่แท้จริงของวิธีการไม่เกี่ยวข้องและในความเป็นจริงควรว่างเปล่า

ตัวอย่างต่อไปนี้กำหนด PointCut ชื่อ 'businessService' ซึ่งจะจับคู่การดำเนินการของทุกวิธีที่มีอยู่ในคลาสภายใต้แพ็คเกจ com.xyz.myapp.service

import org.aspectj.lang.annotation.PointCut;

@PointCut("execution(* com.xyz.myapp.service.*.*(..))") // expression 
private void businessService() {}  // signature

ตัวอย่างต่อไปนี้กำหนด PointCut ชื่อ 'getname' ที่จะจับคู่การดำเนินการของเมธอด getName () ที่มีอยู่ในคลาส Student ภายใต้แพ็คเกจ com.tutorialspoint

import org.aspectj.lang.annotation.PointCut;

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

การประกาศคำแนะนำ

คุณสามารถประกาศคำแนะนำใด ๆ จากห้าข้อโดยใช้คำอธิบายประกอบ @ {ADVICE-NAME} ตามที่ระบุด้านล่าง สิ่งนี้ถือว่าคุณได้กำหนดเมธอดลายเซ็น 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(){
   ...
}

คุณสามารถกำหนด PointCut แบบอินไลน์สำหรับคำแนะนำใด ๆ ต่อไปนี้เป็นตัวอย่างในการกำหนด PointCut แบบอินไลน์สำหรับคำแนะนำก่อน

@Before("execution(* com.xyz.myapp.service.*.*(..))")
public doBeforeTask(){
   ...
}

ในบทนี้เราจะเขียนแอปพลิเคชัน AOP จริงโดยใช้ Spring AOP Framework ก่อนที่คุณจะเริ่มเขียนตัวอย่างแรกของคุณโดยใช้ Spring-WS framework คุณต้องแน่ใจว่าคุณได้ตั้งค่าสภาพแวดล้อม Spring AOP ของคุณอย่างถูกต้องตามที่อธิบายไว้ในSpring Web Services -บทการตั้งค่าสภาพแวดล้อม

ตอนนี้ดำเนินการต่อเพื่อเขียนแอปพลิเคชัน Spring AOP แบบคอนโซลซึ่งจะแสดงแนวคิด AOP

สร้างโครงการ

Step 1 - เปิดคอนโซลคำสั่งไปที่ไดเร็กทอรี C: \ MVN และดำเนินการดังต่อไปนี้ mvn คำสั่ง

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

Maven จะเริ่มประมวลผลและจะสร้างโครงสร้างโครงการแอปพลิเคชัน Java ที่สมบูรณ์

[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- ไปที่ไดเรกทอรี C: / MVN คุณจะเห็นโปรเจ็กต์แอปพลิเคชัน Java ที่สร้างขึ้นโดยตั้งชื่อว่า student (ตามที่ระบุใน artifactId) อัปเดต POM.xml เพื่อรวมการอ้างอิง Spring-AOP เพิ่มไฟล์ MainApp.java, Student.java และ 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());   
   }
   
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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 - เพิ่มไฟล์กำหนดค่า Beans.xml ภายใต้ src > main > resources โฟลเดอร์

<?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 - เปิดคอนโซลคำสั่งไปที่ไดเร็กทอรี C: \ MVN และดำเนินการดังต่อไปนี้ mvn คำสั่ง

C:\MVN>Student> mvn package

Maven จะเริ่มประมวลผลและดาวน์โหลดไลบรารีที่ต้องการ

[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] ------------------------------------------------------------------------

อิมพอร์ตโปรเจ็กต์ใน Eclipse

Step 1 - เปิด Eclipse

Step 2 - เลือก File → Import → ตัวเลือก

Step 3- เลือก Maven Projects Option คลิกปุ่มถัดไป

Step 4 - เลือกตำแหน่งโครงการที่สร้างโครงการของนักเรียนโดยใช้ Maven

Step 5 - คลิกปุ่มเสร็จสิ้น

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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)

เข้าร่วมจุด

JoinPoint แสดงถึงจุดหนึ่งในแอปพลิเคชันของคุณที่คุณสามารถเสียบด้าน AOP ได้ คุณสามารถพูดได้ว่าเป็นสถานที่จริงในแอปพลิเคชันที่จะดำเนินการโดยใช้ Spring AOP framework พิจารณาตัวอย่างต่อไปนี้ -

  • คลาสเมธอดทั้งหมดที่มีอยู่ในแพ็คเกจ

  • วิธีการเฉพาะของคลาส

PointCut

PointCut คือชุดของ JoinPoints หนึ่งชุดขึ้นไปซึ่งควรดำเนินการตามคำแนะนำ คุณสามารถระบุ PointCuts โดยใช้นิพจน์หรือรูปแบบดังที่เราจะเห็นในตัวอย่าง AOP ของเรา ในฤดูใบไม้ผลิ PointCut ช่วยในการใช้ JoinPoints เฉพาะเพื่อใช้คำแนะนำ พิจารณาตัวอย่างต่อไปนี้ -

  • นิพจน์ = "การดำเนินการ (* com.tutorialspoint. *. * (.. ))"

  • นิพจน์ = "การดำเนินการ (* com.tutorialspoint.Student.getName (.. ))"

ไวยากรณ์

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

ที่ไหน

  • adviceClass - อ้างอิงของคลาสที่มีวิธีการแนะนำ

  • PointCut-id - รหัสของ PointCut

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ JoinPoint และ PointCut ให้เราเขียนตัวอย่างซึ่งจะนำ PointCuts ไปใช้ หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เมื่อคุณสร้างไฟล์คอนฟิกซอร์สและบีนเสร็จแล้วให้รันแอปพลิเคชัน หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

<aop: pointcut> ที่กำหนดไว้ข้างต้นจะเลือกวิธีการทั้งหมดที่กำหนดไว้ภายใต้แพ็คเกจ com.tutorialspoint สมมติว่าคุณต้องการดำเนินการตามคำแนะนำของคุณก่อนหรือหลังวิธีการใดวิธีหนึ่งคุณสามารถกำหนด PointCut เพื่อ จำกัด การดำเนินการของคุณให้แคบลงโดยการแทนที่ดาว (*) ในนิยาม PointCut ด้วยชื่อคลาสและเมธอดจริง ต่อไปนี้เป็นไฟล์คอนฟิกูเรชัน 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

Beforeเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานก่อนที่จะดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำก่อน

ไวยากรณ์

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

ที่ไหน

  • PointCut-id - รหัสของ PointCut

  • methodName - ชื่อวิธีการของฟังก์ชันที่จะเรียกก่อนฟังก์ชันที่เรียก

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ Before Advice ให้เราเขียนตัวอย่างซึ่งจะนำไปใช้ Before Advice หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างไฟล์ซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้รันแอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

Afterเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหลังจากการดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำหลัง

ไวยากรณ์

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

ที่ไหน

  • PointCut-id - รหัสของ PointCut

  • methodName - ชื่อวิธีการของฟังก์ชันที่จะเรียกหลังจากฟังก์ชันที่เรียก

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ After Advice ให้เราเขียนตัวอย่างซึ่งจะนำไปใช้ After Advice หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างไฟล์ซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้รันแอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณสิ่งนี้จะพิมพ์ข้อความต่อไปนี้

Name : Zara
Age : 11
Student profile setup complete.

Afterเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหลังจากการดำเนินการตามวิธีการเฉพาะเมื่อวิธีการนั้นเสร็จสมบูรณ์ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำหลัง

ไวยากรณ์

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

ที่ไหน

  • PointCut-id - รหัสของ PointCut

  • methodName - ชื่อเมธอดของฟังก์ชันที่จะเรียกหลังจากฟังก์ชันที่เรียกคืนค่าสำเร็จ

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับคำแนะนำหลังจากกลับมาให้เราเขียนตัวอย่างซึ่งจะใช้คำแนะนำหลังจากกลับมา ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Name : Zara
Returning : Name
Age : 11
Exception raised

After-throwingเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหลังจากการดำเนินการเมธอดต่อเมื่อเมธอดนั้นออกไปโดยทิ้งข้อยกเว้น ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำหลังการขว้าง

ไวยากรณ์

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

ที่ไหน

  • PointCut-id - รหัสของ PointCut

  • ex - ข้อยกเว้นที่จะโยน

  • methodName - ชื่อเมธอดของฟังก์ชันที่จะเรียกใช้เมื่อฟังก์ชันที่เรียกแสดงข้อยกเว้นและออก

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ After Throwing Advice ให้เราเขียนตัวอย่างซึ่งจะนำไปใช้ After Throwing Advice ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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)

Aroundเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานก่อนและหลังการดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำรอบ ๆ

ไวยากรณ์

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

ที่ไหน

  • PointCut-id - รหัสของ PointCut

  • methodName - ชื่อวิธีการของฟังก์ชันที่จะเรียกก่อนฟังก์ชันที่เรียก

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ Around Advice ให้เราเขียนตัวอย่างซึ่งจะนำไปใช้ Around Advice ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Around advice
Name : Zara
Returning Zara

ให้เราเขียนตัวอย่างซึ่งจะใช้คำแนะนำโดยใช้การกำหนดค่าตามคำอธิบายประกอบ สำหรับสิ่งนี้ให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

JoinPoint

JoinPoint แสดงถึงจุดหนึ่งในแอปพลิเคชันของคุณที่คุณสามารถเสียบด้าน AOP ได้ คุณสามารถพูดได้ว่าเป็นสถานที่จริงในแอปพลิเคชันที่จะดำเนินการโดยใช้ Spring AOP framework พิจารณาตัวอย่างต่อไปนี้ -

  • คลาสเมธอดทั้งหมดที่มีอยู่ในแพ็คเกจ

  • วิธีการเฉพาะของคลาส

PointCut

PointCut คือชุดของ JoinPoint อย่างน้อยหนึ่งรายการที่ควรดำเนินการตามคำแนะนำ คุณสามารถระบุ PointCuts โดยใช้นิพจน์หรือรูปแบบดังที่เราจะเห็นในตัวอย่าง AOP ของเรา ในฤดูใบไม้ผลิ PointCut ช่วยในการใช้ JoinPoints เฉพาะเพื่อใช้คำแนะนำ พิจารณาตัวอย่างต่อไปนี้ -

  • @PointCut ("การดำเนินการ (* com.tutorialspoint. *. * (.. ))")

  • @PointCut ("การดำเนินการ (* com.tutorialspoint.Student.getName (.. ))")

ไวยากรณ์

@Aspect
public class Logging {

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

}

ที่ไหน

  • @Aspect - ทำเครื่องหมายชั้นเรียนเป็นชั้นเรียนที่มีวิธีการแนะนำ

  • @PointCut - ทำเครื่องหมายฟังก์ชันเป็น PointCut

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ JoinPoint และ PointCut ให้เราเขียนตัวอย่างซึ่งจะนำ PointCuts ไปใช้ ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

@Pointcut ที่กำหนดไว้ข้างต้นใช้นิพจน์เพื่อเลือกวิธีการทั้งหมดที่กำหนดไว้ภายใต้แพ็คเกจ com.tutorialspoint @ คำแนะนำก่อนใช้ PointCut ที่กำหนดไว้ข้างต้นเป็นพารามิเตอร์ วิธีการ beforeAdvice () อย่างมีประสิทธิภาพจะถูกเรียกก่อนทุกวิธีที่ครอบคลุมโดย PointCut

@Beforeเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานก่อนที่จะดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำ @Before

ไวยากรณ์

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

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

ที่ไหน

  • @PointCut - ทำเครื่องหมายฟังก์ชันเป็น PointCut

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

  • @Before - ทำเครื่องหมายฟังก์ชันเป็นคำแนะนำที่จะดำเนินการก่อนที่เมธอดจะครอบคลุมโดย PointCut

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ @Before Advice ให้เราเขียนตัวอย่างที่จะนำไปใช้ @Before Advice ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

@Pointcut ที่กำหนดไว้ด้านบนใช้นิพจน์เพื่อเลือกเมธอด getAge () ที่กำหนดในคลาส (es) ภายใต้แพ็คเกจ com.tutorialspoint @ หลังจากคำแนะนำใช้ PointCut ที่กำหนดไว้ข้างต้นเป็นพารามิเตอร์ จะเรียกเมธอด afterAdvice () อย่างมีประสิทธิภาพก่อนทุกวิธีที่ครอบคลุมโดย PointCut

@Afterเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหลังจากการดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำ @After

ไวยากรณ์

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

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

ที่ไหน

  • @PointCut - ทำเครื่องหมายฟังก์ชันเป็น PointCut

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

  • @After - ทำเครื่องหมายฟังก์ชันเป็นคำแนะนำที่จะดำเนินการก่อนที่เมธอดจะครอบคลุมโดย PointCut

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ @After Advice ให้เราเขียนตัวอย่างที่จะนำไปใช้ @After Advice หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Name : Zara
Age : 11
Student profile setup completed.

@Pointcut ที่กำหนดไว้ด้านบนใช้นิพจน์เพื่อเลือกเมธอด getAge () ที่กำหนดในคลาส (es) ภายใต้แพ็คเกจ com.tutorialspoint @ หลังจากคำแนะนำใช้ PointCut ที่กำหนดไว้ข้างต้นเป็นพารามิเตอร์ จะเรียกเมธอด afterAdvice () อย่างมีประสิทธิภาพก่อนทุกวิธีที่ครอบคลุมโดย PointCut

@AfterReturningเป็นประเภทคำแนะนำซึ่งช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหลังจากวิธีดำเนินการสำเร็จ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำ @AfterReturning

ไวยากรณ์

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

ที่ไหน

  • @AfterReturning - ทำเครื่องหมายฟังก์ชันเป็นคำแนะนำที่จะดำเนินการก่อนที่เมธอดจะครอบคลุมโดย PointCut หากวิธีการคืนค่าสำเร็จ

  • PointCut - จัดเตรียมนิพจน์เพื่อเลือกฟังก์ชัน

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

  • returning - ชื่อของตัวแปรที่จะส่งคืน

หากต้องการทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับคำแนะนำ @AfterReturning ให้เราเขียนตัวอย่างซึ่งจะใช้คำแนะนำ @AfterReturning หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

@AfterThrowingเป็นประเภทคำแนะนำที่ช่วยให้มั่นใจได้ว่าคำแนะนำจะทำงานหากเมธอดมีข้อยกเว้น ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำ @AfterThrowing

ไวยากรณ์

@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);  
}

ที่ไหน

  • @AfterThrowing - ทำเครื่องหมายฟังก์ชันเป็นคำแนะนำที่จะดำเนินการก่อนที่เมธอดจะครอบคลุมโดย PointCut หากเมธอดมีข้อยกเว้น

  • PointCut - จัดเตรียมนิพจน์เพื่อเลือกฟังก์ชัน

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

  • throwing - ชื่อของข้อยกเว้นที่จะส่งคืน

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับคำแนะนำ @AfterThrowing ให้เราเขียนตัวอย่างที่จะนำไปใช้ @AfterThrowing Advice หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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);  
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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)

@Aroundเป็นประเภทคำแนะนำซึ่งช่วยให้มั่นใจได้ว่าคำแนะนำสามารถทำงานก่อนและหลังการดำเนินการตามวิธีการ ต่อไปนี้เป็นไวยากรณ์ของคำแนะนำ @Around

ไวยากรณ์

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

ที่ไหน

  • @PointCut - ทำเครื่องหมายฟังก์ชันเป็น PointCut

  • execution( expression ) - นิพจน์ครอบคลุมวิธีการที่จะนำคำแนะนำไปใช้

  • @Around - ทำเครื่องหมายฟังก์ชันเป็นคำแนะนำที่จะดำเนินการก่อนที่เมธอดจะครอบคลุมโดย PointCut

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ @Around Advice ให้เราเขียนตัวอย่างที่จะนำไปใช้ @Around Advice ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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);
   }  
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Around advice
Age : 11
Returning 11

จนถึงตอนนี้เราได้ประกาศแง่มุมต่างๆโดยใช้ <aop:config> หรือ < aop:aspectj-autoproxy>. เราสามารถสร้างพร็อกซีโดยใช้โปรแกรมและเรียกใช้แง่มุมโดยใช้โปรแกรมโดยใช้วัตถุพร็อกซี

ไวยากรณ์

//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();

ที่ไหน

  • AspectJProxyFactory - คลาสโรงงานเพื่อสร้างวัตถุพร็อกซี

  • Logging.class - ระดับของมุมมองที่มีคำแนะนำ

  • Student - ชั้นธุรกิจควรได้รับคำแนะนำ

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับพร็อกซีให้เราเขียนตัวอย่างซึ่งจะใช้พร็อกซี ในการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring -

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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;
   }   
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Going to setup student profile.
Age : 11

ตามนิพจน์ PointCut อาจเป็นกรณีที่พวกเขาถูกนำไปใช้กับถั่วอื่น ๆ โดยที่คำแนะนำไม่ได้ตั้งใจไว้ ตัวอย่างเช่นพิจารณานิพจน์ต่อไปนี้

execution(* com.tutorialspoint.*.getAge(..))

ถั่วสปริงใหม่ถูกเพิ่มด้วยเมธอด getAge () และคำแนะนำจะเริ่มนำไปใช้กับมันแม้ว่าอาจไม่ได้ตั้งใจก็ตาม เพื่อให้บรรลุเป้าหมายนี้เราสามารถสร้างคำอธิบายประกอบที่กำหนดเองและใส่คำอธิบายประกอบวิธีการที่จะนำคำแนะนำไปใช้

@Before("@annotation(com.tutorialspoint.Loggable)")

หากต้องการทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ @Before Advice ให้เราเขียนตัวอย่างที่จะนำไปใช้ @Before Advice หากต้องการเขียนตัวอย่างของเราพร้อมคำแนะนำเล็กน้อยให้เรามี Eclipse IDE ที่ใช้งานได้และใช้ขั้นตอนต่อไปนี้เพื่อสร้างแอปพลิเคชัน Spring

ขั้นตอน คำอธิบาย
1 อัพเดทโครงการนักศึกษาสร้างขึ้นภายใต้บทที่ฤดูใบไม้ผลิ AOP - การประยุกต์ใช้
2 อัปเดตการกำหนดค่า bean และเรียกใช้แอปพลิเคชันตามที่อธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของ Logging.javaไฟล์. นี่คือตัวอย่างของโมดูลด้านข้างซึ่งกำหนดวิธีการที่จะเรียกใช้ในจุดต่างๆ

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ Loggable.java ไฟล์ -

package com.tutorialspoint;

public @interface Loggable {

}

ต่อไปนี้เป็นเนื้อหาของไฟล์ Student.java ไฟล์.

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

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

ต่อไปนี้เป็นไฟล์กำหนดค่า 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>

เรียกใช้โครงการ

เมื่อคุณสร้างซอร์สและไฟล์การกำหนดค่าเสร็จแล้วให้เรียกใช้แอปพลิเคชันของคุณ คลิกขวาที่ MainApp.java ในแอปพลิเคชันของคุณและใช้งานrun as Java Applicationคำสั่ง หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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