स्प्रिंग एओपी - कार्यान्वयन

वसंत समर्थन करता है @AspectJ annotation style दृष्टिकोण और schema-based कस्टम पहलुओं को लागू करने के लिए दृष्टिकोण।

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

   <!-- bean definition & AOP specific configuration -->

</beans>

एक पहलू की घोषणा

एक aspect का उपयोग कर घोषित किया जाता है <aop:aspect> तत्व, और समर्थन बीन का उपयोग करके संदर्भित किया जाता है ref विशेषता निम्नानुसार है।

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

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

यहां "अनियन" कॉन्फ़िगर किया जाएगा और निर्भरता को किसी भी अन्य स्प्रिंग बीन की तरह इंजेक्ट किया जाएगा जैसा कि आपने पिछले अध्यायों में देखा है।

एक PointCut घोषणा

PointCutअलग-अलग सलाह के साथ निष्पादित किए जाने वाले ब्याज के सम्मिलित बिंदुओं (अर्थात तरीकों) को निर्धारित करने में मदद करता है। XML स्कीमा आधारित कॉन्फ़िगरेशन के साथ काम करते समय, प्वाइंटकुट को निम्नानुसार परिभाषित किया जाएगा -

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

निम्न उदाहरण 'BusinessService' नाम के एक पॉइंटकुट को परिभाषित करता है जो पैकेज com.tutorialspoint के तहत छात्र वर्ग में उपलब्ध getName () विधि के निष्पादन से मेल खाएगा।

<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 जावा 5 एनोटेशन के साथ नियमित जावा कक्षाओं के रूप में पहलुओं को घोषित करने की शैली को संदर्भित करता है। आपकी XML स्कीमा-आधारित कॉन्फ़िगरेशन फ़ाइल के अंदर निम्न तत्व को शामिल करके @AspectJ समर्थन सक्षम किया गया है।

<aop:aspectj-autoproxy/>

एक पहलू की घोषणा

पहलू वर्ग किसी भी अन्य सामान्य बीन की तरह हैं और किसी भी अन्य वर्ग की तरह ही तरीके और क्षेत्र हो सकते हैं, सिवाय इसके कि उन्हें @Aspect के साथ निम्नानुसार एनोटेट किया जाएगा।

package org.xyz;

import org.aspectj.lang.annotation.Aspect;

@Aspect
public class AspectModule {

}

उन्हें एक्सएमएल में किसी अन्य बीन की तरह कॉन्फ़िगर किया जाएगा।

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

एक PointCut घोषणा

PointCutअलग-अलग सलाह के साथ निष्पादित किए जाने वाले ब्याज के सम्मिलित बिंदुओं (अर्थात तरीकों) को निर्धारित करने में मदद करता है। @AspectJ आधारित कॉन्फ़िगरेशन के साथ काम करते समय, प्वाइंटकुट घोषणा में दो भाग होते हैं -

  • एक पॉइंटकट अभिव्यक्ति जो यह निर्धारित करती है कि कौन सी विधि निष्पादित होती है जिसमें हम रुचि रखते हैं।

  • एक PointCut हस्ताक्षर जिसमें एक नाम और किसी भी संख्या में पैरामीटर होते हैं। विधि का वास्तविक शरीर अप्रासंगिक है और वास्तव में खाली होना चाहिए।

निम्न उदाहरण 'BusinessService' नाम के एक पॉइंटकूट को परिभाषित करता है जो संकुल com.xyz.myapp.service के तहत कक्षाओं में उपलब्ध हर विधि के निष्पादन से मेल खाएगा।

import org.aspectj.lang.annotation.PointCut;

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

निम्न उदाहरण 'getname' नाम के एक पॉइंटकुट को परिभाषित करता है जो पैकेज com.tutorialspoint के तहत छात्र वर्ग में उपलब्ध getName () विधि के निष्पादन से मेल खाएगा।

import org.aspectj.lang.annotation.PointCut;

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

घोषणाओं की घोषणा

आप नीचे दिए गए अनुसार @ {ADVICE-NAME} एनोटेशन का उपयोग करके किसी भी पांच सलाह की घोषणा कर सकते हैं। यह मानता है कि आपने पहले से ही एक पॉइंटसूट हस्ताक्षर विधि बिज़नेस सर्विस () को परिभाषित किया है।

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

आप किसी भी सलाह के लिए पॉइंटकॉट इनलाइन को परिभाषित कर सकते हैं। निम्नलिखित सलाह से पहले इनलाइन प्वाइंटकुट को परिभाषित करने के लिए एक उदाहरण है।

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