Spring AOP - basé sur XML après renvoi des conseils
Afterest un type de conseil qui garantit qu'un conseil ne s'exécute après l'exécution de la méthode que si la méthode se termine avec succès. Voici la syntaxe du conseil après.
Syntaxe
<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>
Où,
PointCut-id - id du PointCut.
methodName - Nom de méthode de la fonction à appeler après le retour d'une fonction appelée.
Pour comprendre les concepts mentionnés ci-dessus liés aux conseils après retour, écrivons un exemple qui mettra en œuvre les conseils après retour. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisons les étapes suivantes pour créer une application Spring -
Étape | La description |
---|---|
1 | Mettez à jour le projet Student créé sous le chapitre Spring AOP - Application . |
2 | Mettez à jour la configuration du bean et exécutez l'application comme expliqué ci-dessous. |
Voici le contenu de Logging.javafichier. Il s'agit en fait d'un exemple de module d'aspect, qui définit les méthodes à appeler en différents points.
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() );
}
}
Voici le contenu de la Student.java fichier.
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();
}
}
Voici le contenu de la MainApp.java fichier.
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();
}
}
Voici le fichier de configuration 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>
Lancer le projet
Une fois que vous avez terminé de créer les fichiers source et de configuration, exécutez votre application. Cliquez avec le bouton droit sur MainApp.java dans votre application et utilisezrun as Java Applicationcommander. Si tout va bien avec votre application, elle imprimera le message suivant.
Name : Zara
Returning : Name
Age : 11
Exception raised