Spring AOP - Guide rapide
L'un des composants clés de Spring Framework est le Aspect Oriented Programming (AOP)cadre. La programmation orientée aspect implique de décomposer la logique du programme en parties distinctes appeléesso-called concerns. Les fonctions qui couvrent plusieurs points d'une application sont appelées des préoccupations transversales. Celles-cicross-cutting concernssont conceptuellement distincts de la logique métier de l'application. Il existe divers bons exemples communs d'aspects tels que la journalisation, l'audit, les transactions déclaratives, la sécurité, la mise en cache, etc.
L'unité clé de la modularité dans la POO est la classe, tandis que dans l'AOP l'unité de la modularité est l'aspect. L'injection de dépendances vous aide à dissocier les objets de votre application les uns des autres, tandis que l'AOP vous aide à dissocier les préoccupations transversales des objets qu'elles affectent. AOP est comme les déclencheurs dans les langages de programmation tels que Perl, .NET, Java et autres.
Le module Spring AOP permet aux intercepteurs d'intercepter une application. Par exemple, lorsqu'une méthode est exécutée, vous pouvez ajouter des fonctionnalités supplémentaires avant ou après l'exécution de la méthode.
Ce chapitre vous guide tout au long du processus de configuration de Spring AOP sur les systèmes Windows et Linux. Spring AOP peut être facilement installé et intégré à votre environnement Java actuel et MAVEN en suivant quelques étapes simples sans aucune procédure de configuration complexe. L'administration des utilisateurs est requise lors de l'installation.
Configuration requise
JDK | Java SE 2 JDK 1.5 ou supérieur |
Mémoire | 1 Go de RAM (recommandé) |
Espace disque | Aucune exigence minimale |
Version du système d'exploitation | Windows XP ou supérieur, Linux |
Voyons maintenant les étapes d'installation de Spring AOP.
Étape 1: Vérifiez votre installation Java
Tout d'abord, vous devez disposer du kit de développement logiciel Java (SDK) installé sur votre système. Pour vérifier cela, exécutez l'une des deux commandes suivantes en fonction de la plate-forme sur laquelle vous travaillez.
Si l'installation de Java a été effectuée correctement, la version actuelle et les spécifications de votre installation Java seront affichées. Un exemple de sortie est donné dans le tableau suivant.
Plate-forme | Commander | Exemple de sortie |
---|---|---|
les fenêtres | Ouvrez la console de commande et tapez - \>java -version |
Version Java "1.7.0_60" Environnement d'exécution Java (TM) SE (build 1.7.0_60-b19) VM serveur 64 bits Java Hotspot (TM) (build 24.60-b09, mode mixte) |
Linux | Ouvrez le terminal de commande et tapez - $java -version |
version java "1.7.0_25" Ouvrir l'environnement d'exécution JDK (rhel-2.3.10.4.el6_4-x86_64) Ouvrez la machine virtuelle serveur JDK 64 bits (build 23.7-b01, mode mixte) |
Nous supposons que les lecteurs de ce didacticiel ont installé la version 1.7.0_60 du SDK Java sur leur système.
Si vous ne disposez pas du SDK Java, téléchargez sa version actuelle sur https://www.oracle.com/technetwork/java/javase/downloads/index.html et faites-le installer.
Étape 2: définissez votre environnement Java
Définissez la variable d'environnement JAVA_HOME pour qu'elle pointe vers l'emplacement du répertoire de base où Java est installé sur votre machine. Par exemple,
Sr.No. | Plateforme et description |
---|---|
1 | Windows Définissez JAVA_HOME sur C: \ ProgramFiles \ java \ jdk1.7.0_60 |
2 | Linux Exporter JAVA_HOME = / usr / local / java-current |
Ajoutez le chemin complet de l'emplacement du compilateur Java au chemin système.
Sr.No. | Plateforme et description |
---|---|
1 | Windows Ajoutez la chaîne "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" à la fin de la variable système Path. |
2 | Linux Exporter PATH = $ PATH: $ JAVA_HOME / bin / |
Exécutez la commande java -version à partir de l'invite de commande comme expliqué ci-dessus.
Étape 3: Téléchargez l'archive Maven
Téléchargez Maven 3.3.3 depuis https://maven.apache.org/download.cgi
OS | Nom de l'archive |
---|---|
les fenêtres | apache-maven-3.3.3-bin.zip |
Linux | apache-maven-3.3.3-bin.tar.gz |
Mac | apache-maven-3.3.3-bin.tar.gz |
Étape 4: Extraire l'archive Maven
Extrayez l'archive dans le répertoire dans lequel vous souhaitez installer Maven 3.3.3. Le sous-répertoire apache-maven-3.3.3 sera créé à partir de l'archive.
OS | Emplacement (peut être différent en fonction de votre installation) |
---|---|
les fenêtres | C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3 |
Linux | / usr / local / apache-maven |
Mac | / usr / local / apache-maven |
Étape 5: définir les variables d'environnement Maven
Ajoutez M2_HOME, M2, MAVEN_OPTS aux variables d'environnement.
OS | Production |
---|---|
les fenêtres | Définissez les variables d'environnement à l'aide des propriétés système. M2_HOME = C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3 M2 =% M2_HOME% \ bin MAVEN_OPTS = -Xms256m -Xmx512m |
Linux | Ouvrez le terminal de commande et définissez les variables d'environnement. export M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3 export M2 = $ M2_HOME / bin export MAVEN_OPTS = -Xms256m -Xmx512m |
Mac | Ouvrez le terminal de commande et définissez les variables d'environnement. export M2_HOME = /usr/local/apache-maven/apache-maven-3.3.3 export M2 = $ M2_HOME / bin export MAVEN_OPTS = -Xms256m -Xmx512m |
Étape 6: Ajouter l'emplacement du répertoire Maven Bin au chemin système
Maintenant, ajoutez la variable M2 au chemin système.
OS | Production |
---|---|
les fenêtres | Ajoutez la chaîne;% M2% à la fin de la variable système, Path. |
Linux | export PATH = $ M2: $ PATH |
Mac | export PATH = $ M2: $ PATH |
Étape 7: Vérifiez l'installation de Maven
Ouvrez maintenant la console et exécutez ce qui suit mvn commander.
OS | Tâche | Commander |
---|---|---|
les fenêtres | Ouvrez la console de commande | c: \> mvn --version |
Linux | Ouvrir le terminal de commande | $ mvn --version |
Mac | Terminal ouvert | machine: <joseph $ mvn --version |
Enfin, vérifiez la sortie des commandes ci-dessus, qui devrait être quelque chose comme suit -
OS | Production |
---|---|
les fenêtres | Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30) Accueil Maven: C: \ Program Files \ Apache Software Foundation \ apache-maven-3.3.3 Version Java: 1.7.0_75, fournisseur: Oracle Corporation Accueil Java: C: \ Program Files \ Java \ jdk1.7.0_75 \ jre Paramètres régionaux par défaut: en_US, encodage de la plateforme: Cp1252 |
Linux | Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30) Accueil Maven: /usr/local/apache-maven/apache-maven-3.3.3 Version Java: 1.7.0_75, fournisseur: Oracle Corporation Accueil Java: /usr/local/java-current/jdk1.7.0_75/jre |
Mac | Apache Maven 3.3.3 (7994120775791599e205a5524ec3e0dfe41d4a06; 2015-04-22T17: 27: 37 + 05: 30) Accueil Maven: /usr/local/apache-maven/apache-maven-3.3.3 Version Java: 1.7.0_75, fournisseur: Oracle Corporation Accueil Java: /Library/Java/Home/jdk1.7.0_75/jre |
Étape 8 - Configurer Eclipse IDE
Tous les exemples de ce didacticiel ont été écrits à l'aide de l'IDE Eclipse. Je vous suggère donc d'installer la dernière version d'Eclipse sur votre machine.
Pour installer Eclipse IDE, téléchargez les derniers binaires Eclipse à partir de https://www.eclipse.org/downloads/. Une fois l'installation téléchargée, décompressez la distribution binaire dans un emplacement pratique. Par exemple, dans C: \ eclipse sous Windows, ou / usr / local / eclipse sous Linux / Unix et définissez enfin la variable PATH de manière appropriée.
Eclipse peut être démarré en exécutant les commandes suivantes sur la machine Windows, ou vous pouvez double-cliquer sur eclipse.exe
%C:\eclipse\eclipse.exe
Eclipse peut être démarré en exécutant les commandes suivantes sur une machine Unix (Solaris, Linux, etc.) -
$/usr/local/eclipse/eclipse
Après un démarrage réussi, si tout va bien, il devrait afficher le résultat suivant -
Une fois que vous avez terminé cette dernière étape, vous êtes prêt à passer à votre premier exemple AOP, que vous verrez dans le chapitre suivant.
Avant de commencer à travailler avec AOP, familiarisons-nous avec les concepts et les terminologies AOP. Ces termes ne sont pas spécifiques à Spring, ils sont plutôt liés à AOP.
Sr.No. | Termes et description |
---|---|
1 | Aspect Un module qui a un ensemble d'API fournissant des exigences transversales. Par exemple, un module de journalisation serait appelé aspect AOP pour la journalisation. Une application peut avoir un certain nombre d'aspects en fonction de l'exigence. |
2 | Join point Cela représente un point dans votre application où vous pouvez intégrer l'aspect AOP. Vous pouvez également dire que c'est l'endroit réel dans l'application où une action sera entreprise à l'aide du framework Spring AOP. |
3 | Advice Il s'agit de l'action réelle à entreprendre avant ou après l'exécution de la méthode. Il s'agit du morceau de code qui est appelé lors de l'exécution du programme par le framework Spring AOP. |
4 | PointCut Il s'agit d'un ensemble d'un ou plusieurs points de jonction où un conseil doit être exécuté. Vous pouvez spécifier des PointCuts à l'aide d'expressions ou de modèles comme nous le verrons dans nos exemples AOP. |
5 | Introduction Une introduction vous permet d'ajouter de nouvelles méthodes ou attributs aux classes existantes. |
6 | Target object L'objet étant conseillé par un ou plusieurs aspects. Cet objet sera toujours un objet mandaté. Aussi appelé objet conseillé. |
sept | Weaving Le tissage est le processus de liaison d'aspects avec d'autres types d'application ou objets pour créer un objet conseillé. Cela peut être fait au moment de la compilation, du chargement ou de l'exécution. |
Les aspects Spring peuvent fonctionner avec cinq types de conseils mentionnés dans le tableau suivant.
Sr.No. | Conseils et description |
---|---|
1 | before Exécutez le conseil avant l'exécution de la méthode. |
2 | after Exécutez le conseil après l'exécution de la méthode, quel que soit son résultat. |
3 | after-returning Exécutez le conseil après l'exécution de la méthode, uniquement si la méthode se termine avec succès. |
4 | after-throwing Exécutez le conseil après l'exécution de la méthode, uniquement si la méthode se termine en lançant une exception. |
5 | around Exécutez le conseil avant et après l'appel de la méthode conseillée. |
Spring soutient le @AspectJ annotation style approche et le schema-based approche pour implémenter les aspects personnalisés.
Basé sur un schéma XML
Les aspects sont implémentés en utilisant des classes régulières avec une configuration basée sur XML.
Pour utiliser les balises d'espace de noms AOP décrites dans cette section, vous devez importer le schéma Spring AOP, décrit comme suit:
<?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>
Déclarer un aspect
Un aspect est déclaré en utilisant le <aop:aspect> élément, et le bean de support est référencé à l'aide de ref attribut comme suit.
<aop:config>
<aop:aspect id = "myAspect" ref = "aBean">
...
</aop:aspect>
</aop:config>
<bean id = "aBean" class = "...">
...
</bean>
Ici, "aBean" sera configuré et la dépendance injectée comme n'importe quel autre bean Spring comme vous l'avez vu dans les chapitres précédents.
Déclarer un PointCut
UNE PointCutaide à déterminer les points de jonction (c'est-à-dire les méthodes) d'intérêt à exécuter avec différents conseils. Lorsque vous travaillez avec une configuration basée sur un schéma XML, PointCut sera défini comme suit -
<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>
L'exemple suivant définit un PointCut nommé 'businessService' qui correspondra à l'exécution de la méthode getName () disponible dans la classe Student sous le package 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>
Déclarer des avis
Vous pouvez déclarer n'importe lequel des cinq conseils dans un <aop: aspect> en utilisant l'élément <aop: {ADVICE NAME}> comme suit.
<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>
Vous pouvez utiliser le même doRequiredTaskou différentes méthodes pour différents conseils. Ces méthodes seront définies dans le cadre du module aspect.
@AspectJ basé
@AspectJ fait référence à un style de déclaration d'aspects en tant que classes Java régulières annotées avec des annotations Java 5. La prise en charge de @AspectJ est activée en incluant l'élément suivant dans votre fichier de configuration basé sur un schéma XML.
<aop:aspectj-autoproxy/>
Déclarer un aspect
Les classes Aspects sont comme n'importe quel autre bean normal et peuvent avoir des méthodes et des champs comme n'importe quelle autre classe, sauf qu'ils seront annotés avec @Aspect comme suit.
package org.xyz;
import org.aspectj.lang.annotation.Aspect;
@Aspect
public class AspectModule {
}
Ils seront configurés en XML comme tout autre bean comme suit.
<bean id = "myAspect" class = "org.xyz.AspectModule">
<!-- configure properties of aspect here as normal -->
</bean>
Déclarer un PointCut
UNE PointCutaide à déterminer les points de jonction (c'est-à-dire les méthodes) d'intérêt à exécuter avec différents conseils. Lorsque vous travaillez avec une configuration basée sur @AspectJ, la déclaration PointCut comporte deux parties -
Une expression PointCut qui détermine exactement les exécutions de méthode qui nous intéressent.
Une signature PointCut comprenant un nom et un nombre quelconque de paramètres. Le corps réel de la méthode n'est pas pertinent et devrait en fait être vide.
L'exemple suivant définit un PointCut nommé 'businessService' qui correspondra à l'exécution de chaque méthode disponible dans les classes sous le package com.xyz.myapp.service.
import org.aspectj.lang.annotation.PointCut;
@PointCut("execution(* com.xyz.myapp.service.*.*(..))") // expression
private void businessService() {} // signature
L'exemple suivant définit un PointCut nommé 'getname' qui correspondra à l'exécution de la méthode getName () disponible dans la classe Student sous le package com.tutorialspoint.
import org.aspectj.lang.annotation.PointCut;
@PointCut("execution(* com.tutorialspoint.Student.getName(..))")
private void getname() {}
Déclarer des avis
Vous pouvez déclarer l'un des cinq avis en utilisant les annotations @ {ADVICE-NAME} comme indiqué ci-dessous. Cela suppose que vous ayez déjà défini une méthode de signature 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(){
...
}
Vous pouvez définir PointCut en ligne pour n'importe lequel des conseils. Voici un exemple de définition de PointCut en ligne pour les conseils avant.
@Before("execution(* com.xyz.myapp.service.*.*(..))")
public doBeforeTask(){
...
}
Dans ce chapitre, nous allons écrire des applications AOP réelles en utilisant Spring AOP Framework. Avant de commencer à écrire votre premier exemple à l'aide du framework Spring-WS, vous devez vous assurer que vous avez correctement configuré votre environnement Spring AOP, comme expliqué dans le chapitre Spring Web Services - Configuration de l'environnement .
Maintenant, continuez à écrire une application Spring AOP simple comme console, qui démontrera les concepts AOP.
Créer un projet
Step 1 - Ouvrez une console de commande, accédez au répertoire C: \ MVN et exécutez ce qui suit mvn commander.
C:\MVN>mvn archetype:generate -DgroupId = com.tutorialspoint -DartifactId = Student
-DarchetypeArtifactId = maven-archetype-quickstart -DinteractiveMode = false
Maven commencera le traitement et créera la structure complète du projet d'application 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- Accédez au répertoire C: / MVN. Vous verrez un projet d'application Java créé, nommé student (comme spécifié dans artifactId). Mettez à jour le POM.xml pour inclure les dépendances Spring-AOP. Ajoutez les fichiers MainApp.java, Student.java et 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());
}
}
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();
student.printThrowException();
}
}
Step 3 - Ajouter le fichier de configuration Beans.xml en dessous de src > main > resources dossier.
<?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 - Ouvrez la console de commande, accédez au répertoire C: \ MVN et exécutez ce qui suit mvn commander.
C:\MVN>Student> mvn package
Maven commencera le traitement et le téléchargement des bibliothèques requises.
[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] ------------------------------------------------------------------------
Importer un projet dans Eclipse
Step 1 - Ouvrez Eclipse.
Step 2 - Sélectionnez File → Import → option.
Step 3- Sélectionnez l'option Projets Maven. Cliquez sur le bouton Suivant.
Step 4 - Sélectionnez l'emplacement du projet, où le projet étudiant a été créé à l'aide de Maven.
Step 5 - Cliquez sur le bouton Terminer.
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
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)
Rejoindre le point
Un JoinPoint représente un point de votre application où vous pouvez insérer un aspect AOP. Vous pouvez également dire que c'est l'endroit réel dans l'application où une action sera entreprise à l'aide du framework Spring AOP. Considérez les exemples suivants -
Toutes les classes de méthodes contenues dans un ou plusieurs packages.
Une méthode particulière d'une classe.
PointCut
PointCut est un ensemble d'un ou plusieurs JoinPoints où un conseil doit être exécuté. Vous pouvez spécifier des PointCuts à l'aide d'expressions ou de modèles comme nous le verrons dans nos exemples AOP. Au printemps, PointCut aide à utiliser des JoinPoints spécifiques pour appliquer les conseils. Considérez les exemples suivants -
expression = "exécution (* com.tutorialspoint. *. * (..))"
expression = "exécution (* com.tutorialspoint.Student.getName (..))"
Syntaxe
<aop:config>
<aop:aspect id = "log" ref = "adviceClass">
<aop:PointCut id = "PointCut-id" expression = "execution( expression )"/>
</aop:aspect>
</aop:config>
Où,
adviceClass - ref de la classe contenant les méthodes de conseil
PointCut-id - identifiant du PointCut
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
Pour comprendre les concepts mentionnés ci-dessus liés à JoinPoint et PointCut, écrivons un exemple qui implémentera quelques-uns des PointCuts. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisez 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
* before a selected method execution.
*/
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: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>
Une fois que vous avez terminé de créer les fichiers de configuration source et bean, exécutez l'application. Si tout va bien avec votre application, elle imprimera le message suivant.
Going to setup student profile.
Name : Zara
Going to setup student profile.
Age : 11
Le <aop: pointcut> défini ci-dessus sélectionne toutes les méthodes définies sous le package com.tutorialspoint. Supposons que vous souhaitiez exécuter votre conseil avant ou après une méthode particulière, vous pouvez définir votre PointCut pour affiner votre exécution en remplaçant les étoiles (*) dans la définition PointCut par les noms de classe et de méthode réels. Voici un fichier de configuration XML modifié pour montrer le concept.
<?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>
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
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 avant.
Syntaxe
<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>
Où,
PointCut-id - id du PointCut.
methodName - Nom de méthode de la fonction à appeler avant une fonction appelée.
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 utilisez 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
* before a selected method execution.
*/
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: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>
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
Afterest un type de conseil qui garantit qu'un avis s'exécute après l'exécution de la méthode. 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 PointCut-ref = "PointCut-id" method = "methodName"/>
</aop:aspect>
</aop:config>
Où,
PointCut-id - id du PointCut.
methodName - Nom de méthode de la fonction à appeler après une fonction appelée.
Pour comprendre les concepts mentionnés ci-dessus liés à l'After Advice, écrivons un exemple qui implémentera l'After Advice. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisez 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
* after a selected method execution.
*/
public void afterAdvice(){
System.out.println("Student profile setup complete.");
}
}
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: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>
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, cela imprimera le message suivant.
Name : Zara
Age : 11
Student profile setup complete.
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
After-throwingest un type de conseil qui garantit qu'un conseil s'exécute après l'exécution de la méthode, uniquement si la méthode se termine en lançant une exception. Voici la syntaxe des conseils après le lancement.
Syntaxe
<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>
Où,
PointCut-id - id du PointCut.
ex - Exception à lever.
methodName - Nom de méthode de la fonction à appeler lorsqu'une fonction appelée lève une exception et se termine.
Pour comprendre les concepts mentionnés ci-dessus liés à After Throwing Advice, écrivons un exemple qui implémentera After Throwing 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;
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());
}
}
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.printThrowException();
}
}
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-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>
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.
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)
Aroundest un type de conseil qui garantit qu'un avis s'exécute avant et après l'exécution de la méthode. Voici la syntaxe des conseils autour.
Syntaxe
<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>
Où,
PointCut-id - id du PointCut.
methodName - Nom de méthode de la fonction à appeler avant une fonction appelée.
Pour comprendre les concepts mentionnés ci-dessus liés à Around Advice, écrivons un exemple qui implémentera Around 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.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();
}
}
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();
}
}
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 = "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>
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.
Around advice
Name : Zara
Returning Zara
Écrivons un exemple qui implémentera des conseils en utilisant la configuration basée sur les annotations. Pour cela, 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.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.");
}
}
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
Going to setup student profile.
Age : 11
JoinPoint
Un JoinPoint représente un point de votre application où vous pouvez insérer un aspect AOP. Vous pouvez également dire que c'est l'endroit réel dans l'application où une action sera entreprise à l'aide du framework Spring AOP. Considérez les exemples suivants -
Toutes les classes de méthodes contenues dans un ou plusieurs packages.
Une méthode particulière d'une classe.
PointCut
PointCut est un ensemble d'un ou plusieurs JoinPoint où un conseil doit être exécuté. Vous pouvez spécifier des PointCuts à l'aide d'expressions ou de modèles comme nous le verrons dans nos exemples AOP. Au printemps, PointCut aide à utiliser des JoinPoints spécifiques pour appliquer les conseils. Considérez les exemples suivants -
@PointCut ("exécution (* com.tutorialspoint. *. * (..))")
@PointCut ("exécution (* com.tutorialspoint.Student.getName (..))")
Syntaxe
@Aspect
public class Logging {
@PointCut("execution(* com.tutorialspoint.*.*(..))")
private void selectAll(){}
}
Où,
@Aspect - Marquer une classe comme classe contenant des méthodes de conseil.
@PointCut - Marquer une fonction comme PointCut
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
Pour comprendre les concepts mentionnés ci-dessus liés à JoinPoint et PointCut, écrivons un exemple qui implémentera quelques-uns des PointCuts. 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.*.*(..))")
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.");
}
}
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
Going to setup student profile.
Age : 11
Le @Pointcut défini ci-dessus utilise une expression pour sélectionner toutes les méthodes définies sous le package com.tutorialspoint. @Before Advice utilise le PointCut défini ci-dessus comme paramètre. En fait, la méthode beforeAdvice () sera appelée avant chaque méthode couverte par PointCut ci-dessus.
@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.
@Afterest un type de conseil qui garantit qu'un avis s'exécute après l'exécution de la méthode. Voici la syntaxe de @After advice.
Syntaxe
@PointCut("execution(* com.tutorialspoint.Student.getAge(..))")
private void selectGetName(){}
@After("selectGetAge()")
public void afterAdvice(){
System.out.println("Student profile setup completed.");
}
Où,
@PointCut - Marquer une fonction comme PointCut
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
@After - 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 à @After Advice, écrivons un exemple qui implémentera @After Advice. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisez 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.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.");
}
}
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.
Name : Zara
Age : 11
Student profile setup completed.
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.
@AfterReturningest un type de conseil, qui garantit qu'un avis s'exécute une fois la méthode exécutée avec succès. Voici la syntaxe du conseil @AfterReturning.
Syntaxe
@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() );
}
Où,
@AfterReturning - Marquer une fonction comme un conseil à exécuter avant les méthodes couvertes par PointCut, si la méthode retourne avec succès.
PointCut - Fournit une expression pour sélectionner une fonction
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
returning - Nom de la variable à renvoyer.
Pour comprendre les concepts mentionnés ci-dessus liés à @AfterReturning Advice, écrivons un exemple qui implémentera @AfterReturning Advice. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisez 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.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() );
}
}
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.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.
Age : 11
Method Signature: Integer com.tutorialspoint.Student.getAge()
Returning 11
@AfterThrowingest un type de conseil qui garantit qu'un conseil s'exécute si la méthode lève une exception. Voici la syntaxe du conseil @AfterThrowing.
Syntaxe
@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);
}
Où,
@AfterThrowing - Marquer une fonction comme un conseil à exécuter avant la ou les méthodes couvertes par PointCut, si la méthode lève une exception.
PointCut - Fournit une expression pour sélectionner une fonction.
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
throwing - Nom de l'exception à renvoyer.
Pour comprendre les concepts mentionnés ci-dessus liés à @AfterThrowing Advice, écrivons un exemple qui implémentera @AfterThrowing Advice. Pour écrire notre exemple avec quelques conseils, mettons en place un IDE Eclipse fonctionnel et utilisez 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.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);
}
}
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.printThrowException();
}
}
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.
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)
@Aroundest un type de conseil, qui garantit qu'un conseil peut s'exécuter avant et après l'exécution de la méthode. Voici la syntaxe du conseil @Around.
Syntaxe
@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();
}
Où,
@PointCut - Marquer une fonction comme PointCut
execution( expression ) - Expression couvrant les méthodes sur lesquelles les conseils doivent être appliqués.
@Around - 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 à @Around Advice, écrivons un exemple qui implémentera @Around 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.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);
}
}
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.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.
Around advice
Age : 11
Returning 11
Jusqu'à présent, nous avons déclaré les aspects en utilisant <aop:config> ou < aop:aspectj-autoproxy>. Nous pouvons créer un proxy par programme et invoquer les aspects par programme à l'aide de l'objet proxy.
Syntaxe
//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();
Où,
AspectJProxyFactory - Classe d'usine pour créer un objet proxy.
Logging.class - Classe de l'aspect contenant des conseils.
Student - Classe affaires à conseiller.
Pour comprendre les concepts mentionnés ci-dessus liés au proxy, écrivons un exemple qui implémentera le proxy. 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.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.");
}
}
Voici le contenu de la Student.java fichier.
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;
}
}
Voici le contenu de la MainApp.java fichier.
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();
}
}
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 ">
<!-- 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>
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.
Age : 11
Selon les expressions PointCut, il se peut qu'elles soient appliquées à d'autres beans pour lesquels les conseils ne sont pas destinés. Par exemple, considérez l'expression suivante.
execution(* com.tutorialspoint.*.getAge(..))
Un nouveau haricot printanier est ajouté avec la méthode getAge () et les conseils commenceront à lui être appliqués bien que cela ne soit pas prévu. Pour ce faire, nous pouvons créer une annotation personnalisée et annoter les méthodes sur lesquelles le conseil doit être appliqué.
@Before("@annotation(com.tutorialspoint.Loggable)")
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 utilisez 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.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.");
}
}
Voici le contenu de la Loggable.java fichier -
package com.tutorialspoint;
public @interface Loggable {
}
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;
}
@Loggable
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