Spring AOP - Annotation basée avant avis
@Beforeest un type de conseil qui garantit qu'un avis s'exécute avant l'exécution de la méthode. Voici la syntaxe du conseil @Before.
Syntaxe
@PointCut("execution(* com.tutorialspoint.Student.getName(..))")
private void selectGetName(){}
@Before("selectGetName()")
public void beforeAdvice(){
System.out.println("Going to setup student profile.");
}
Où,
@PointCut - Marquer une fonction comme PointCut
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
@Before - Marquer une fonction comme un conseil à exécuter avant la ou les méthodes couvertes par PointCut.
Pour comprendre les concepts mentionnés ci-dessus liés à @Before Advice, écrivons un exemple qui implémentera @Before Advice. 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;
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.");
}
}
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 );
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: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>
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.
Going to setup student profile.
Name : Zara
Age : 11
Le @Pointcut défini ci-dessus utilise une expression pour sélectionner la méthode getAge () définie dans la (les) classe (s) sous le package com.tutorialspoint. @After advice utilise le PointCut défini ci-dessus comme paramètre. En effet, la méthode afterAdvice () sera appelée avant chaque méthode couverte par le PointCut ci-dessus.