By
using after returning advice, we can get the result in the advice.
Create
the class that contains business logic.
Employee.java
==========
package
com.mohan;  
public  class Employee{  
    public int m(){System.out.println("m
method invoked");return 2;}  
    public int k(){System.out.println("k
method invoked");return 3;}  
    public void
k1(){System.out.println("k1 method invoked");}
}       
Create
the aspect class that contains after returning advice.
TrackEmployee.java
============= 
package
com.mohan;  
import
org.aspectj.lang.JoinPoint;  
import
org.aspectj.lang.annotation.AfterReturning; 
import
org.aspectj.lang.annotation.Aspect;  
@Aspect  
public
class TrackEmployee{  
    @AfterReturning(  
              pointcut = "execution(*
Employee.*(..))",  
              returning=
"result")  
    public void myadvice(JoinPoint jp,Object
result)//it is advice (after returning advice) 
    {  
        System.out.println("additional
concern");  
        System.out.println("Method
Signature: "  +
jp.getSignature());  
        System.out.println("Result in
advice: "+result);  
        System.out.println("end of after
returning advice...");  
    }  
}  
Now
create the Beans.xml file that defines beans.
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.xsd   
      
http://www.springframework.org/schema/aop   
      
http://www.springframework.org/schema/aop/spring-aop.xsd">  
    <bean id="empBean"
class="com.mohan.Employee">  
</bean>  
    <bean id="trackEmp"
class="com.mohan.TrackEmployee"></bean>  
    <bean
class="org.springframework.aop.aspectj.annotation.AnnotationAwareAspectJAutoProxyCreator"></bean>  
</beans>   
Now,
let's call the actual method.
Test.java
======
package
com.mohan;  
import
org.springframework.context.ApplicationContext; 
import
org.springframework.context.support.ClassPathXmlApplicationContext;  
public
class Test{  
    public static void main(String[]
args){  
        ApplicationContext context = new
ClassPathXmlApplicationContext("Beans.xml");  
        Employee e = (Employee)
context.getBean("empBean");  
        System.out.println("calling
m...");  
        System.out.println(e.m());  
        System.out.println("calling
k...");  
        System.out.println(e.k());
        System.out.println("calling
k1...");  
        e.k1();
    }  
}  
Expected Output
calling
m...  
m()
method invoked  
additional
concern  
Method
Signature: int com.javatpoint.Operation.m() 
Result
in advice: 2  
end
of after returning advice...  
2  
calling
k...  
k()
method invoked  
additional
concern  
Method
Signature: int com.javatpoint.Operation.k() 
Result
in advice: 3  
end
of after returning advice...  
3  
You
can see that return value is printed two times, one is printed by TrackEmployee
class and second by Test class.
No comments:
Post a Comment