Spring - Configuration basée sur Java

Jusqu'à présent, vous avez vu comment nous configurons les beans Spring à l'aide d'un fichier de configuration XML. Si vous êtes à l'aise avec la configuration XML, il n'est vraiment pas nécessaire d'apprendre comment procéder avec la configuration basée sur Java car vous allez obtenir le même résultat en utilisant l'une des configurations disponibles.

L'option de configuration basée sur Java vous permet d'écrire la plupart de votre configuration Spring sans XML, mais à l'aide de quelques annotations basées sur Java expliquées dans ce chapitre.

Annotations @Configuration et @Bean

Annoter une classe avec le @Configurationindique que la classe peut être utilisée par le conteneur Spring IoC comme source de définitions de bean. le@BeanL'annotation indique à Spring qu'une méthode annotée avec @Bean renverra un objet qui doit être enregistré en tant que bean dans le contexte de l'application Spring. La classe @Configuration la plus simple possible serait la suivante -

package com.tutorialspoint;
import org.springframework.context.annotation.*;

@Configuration
public class HelloWorldConfig {
   @Bean 
   public HelloWorld helloWorld(){
      return new HelloWorld();
   }
}

Le code ci-dessus sera équivalent à la configuration XML suivante -

<beans>
   <bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" />
</beans>

Ici, le nom de la méthode est annoté avec @Bean fonctionne comme ID de bean et il crée et renvoie le bean réel. Votre classe de configuration peut avoir une déclaration pour plus d'un @Bean. Une fois vos classes de configuration définies, vous pouvez les charger et les fournir au conteneur Spring en utilisant AnnotationConfigApplicationContext comme suit -

public static void main(String[] args) {
   ApplicationContext ctx = new AnnotationConfigApplicationContext(HelloWorldConfig.class);
   
   HelloWorld helloWorld = ctx.getBean(HelloWorld.class);
   helloWorld.setMessage("Hello World!");
   helloWorld.getMessage();
}

Vous pouvez charger différentes classes de configuration comme suit -

public static void main(String[] args) {
   AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();

   ctx.register(AppConfig.class, OtherConfig.class);
   ctx.register(AdditionalConfig.class);
   ctx.refresh();

   MyService myService = ctx.getBean(MyService.class);
   myService.doStuff();
}

Exemple

Laissez-nous mettre en place un IDE Eclipse fonctionnel et suivez les étapes suivantes pour créer une application Spring -

Pas La description
1 Créez un projet avec un nom SpringExample et créez un package com.tutorialspoint sous lesrc dossier dans le projet créé.
2 Ajoutez les bibliothèques Spring requises à l'aide de l' option Ajouter des JAR externes , comme expliqué dans le chapitre Exemple de Spring Hello World .
3 Comme vous utilisez des annotations basées sur Java, vous devez également ajouter CGLIB.jar à partir de votre répertoire d'installation Java et de la bibliothèque ASM.jar qui peut être téléchargée depuis asm.ow2.org .
4 Créez les classes Java HelloWorldConfig , HelloWorld et MainApp sous le package com.tutorialspoint .
5 La dernière étape consiste à créer le contenu de tous les fichiers Java et le fichier de configuration Bean et à exécuter l'application comme expliqué ci-dessous.

Voici le contenu de HelloWorldConfig.java fichier

package com.tutorialspoint;
import org.springframework.context.annotation.*;

@Configuration
public class HelloWorldConfig {
   @Bean 
   public HelloWorld helloWorld(){
      return new HelloWorld();
   }
}

Voici le contenu de HelloWorld.java fichier

package com.tutorialspoint;

public class HelloWorld {
   private String message;

   public void setMessage(String message){
      this.message  = message;
   }
   public void getMessage(){
      System.out.println("Your Message : " + message);
   }
}

Voici le contenu de la MainApp.java fichier

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.*;

public class MainApp {
   public static void main(String[] args) {
      ApplicationContext ctx = 
         new AnnotationConfigApplicationContext(HelloWorldConfig.class);
   
      HelloWorld helloWorld = ctx.getBean(HelloWorld.class);
      helloWorld.setMessage("Hello World!");
      helloWorld.getMessage();
   }
}

Une fois que vous avez terminé de créer tous les fichiers source et d'ajouter les bibliothèques supplémentaires requises, laissez-nous exécuter l'application. Vous devez noter qu'aucun fichier de configuration n'est requis. Si tout va bien avec votre application, elle imprimera le message suivant -

Your Message : Hello World!

Injection de dépendances de bean

Quand @Beans a des dépendances les uns sur les autres, exprimant que la dépendance est aussi simple que d'avoir une méthode de bean en appelant une autre comme suit -

package com.tutorialspoint;
import org.springframework.context.annotation.*;

@Configuration
public class AppConfig {
   @Bean
   public Foo foo() {
      return new Foo(bar());
   }
   @Bean
   public Bar bar() {
      return new Bar();
   }
}

Ici, le bean foo reçoit une référence à bar via l'injection du constructeur. Voyons maintenant un autre exemple de travail.

Exemple

Laissez-nous mettre en place un IDE Eclipse fonctionnel et suivez les étapes suivantes pour créer une application Spring -

Pas La description
1 Créez un projet avec un nom SpringExample et créez un package com.tutorialspoint sous lesrc dossier dans le projet créé.
2 Ajoutez les bibliothèques Spring requises à l'aide de l' option Ajouter des JAR externes , comme expliqué dans le chapitre Exemple de Spring Hello World .
3 Comme vous utilisez des annotations basées sur Java, vous devez également ajouter CGLIB.jar à partir de votre répertoire d'installation Java et de la bibliothèque ASM.jar qui peut être téléchargée depuis asm.ow2.org .
4 Créez les classes Java TextEditorConfig , TextEditor , SpellChecker et MainApp sous le package com.tutorialspoint .
5 La dernière étape consiste à créer le contenu de tous les fichiers Java et le fichier de configuration Bean et à exécuter l'application comme expliqué ci-dessous.

Voici le contenu de TextEditorConfig.java fichier

package com.tutorialspoint;
import org.springframework.context.annotation.*;

@Configuration
public class TextEditorConfig {
   @Bean 
   public TextEditor textEditor(){
      return new TextEditor( spellChecker() );
   }

   @Bean 
   public SpellChecker spellChecker(){
      return new SpellChecker( );
   }
}

Voici le contenu de TextEditor.java fichier

package com.tutorialspoint;

public class TextEditor {
   private SpellChecker spellChecker;

   public TextEditor(SpellChecker spellChecker){
      System.out.println("Inside TextEditor constructor." );
      this.spellChecker = spellChecker;
   }
   public void spellCheck(){
      spellChecker.checkSpelling();
   }
}

Voici le contenu d'un autre fichier de classe dépendant SpellChecker.java

package com.tutorialspoint;

public class SpellChecker {
   public SpellChecker(){
      System.out.println("Inside SpellChecker constructor." );
   }
   public void checkSpelling(){
      System.out.println("Inside checkSpelling." );
   }
}

Voici le contenu de la MainApp.java fichier

package com.tutorialspoint;

import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.*;

public class MainApp {
   public static void main(String[] args) {
      ApplicationContext ctx = 
         new AnnotationConfigApplicationContext(TextEditorConfig.class);

      TextEditor te = ctx.getBean(TextEditor.class);
      te.spellCheck();
   }
}

Une fois que vous avez terminé de créer tous les fichiers source et d'ajouter les bibliothèques supplémentaires requises, laissez-nous exécuter l'application. Vous devez noter qu'aucun fichier de configuration n'est requis. Si tout va bien avec votre application, elle imprimera le message suivant -

Inside SpellChecker constructor.
Inside TextEditor constructor.
Inside checkSpelling.

L'annotation @Import

le @Importl'annotation permet de charger des définitions @Bean à partir d'une autre classe de configuration. Considérez une classe ConfigA comme suit -

@Configuration
public class ConfigA {
   @Bean
   public A a() {
      return new A(); 
   }
}

Vous pouvez importer ci-dessus la déclaration Bean dans une autre déclaration Bean comme suit -

@Configuration
@Import(ConfigA.class)
public class ConfigB {
   @Bean
   public B b() {
      return new B(); 
   }
}

Maintenant, plutôt que de devoir spécifier à la fois ConfigA.class et ConfigB.class lors de l'instanciation du contexte, seul ConfigB doit être fourni comme suit -

public static void main(String[] args) {
   ApplicationContext ctx = new AnnotationConfigApplicationContext(ConfigB.class);
   
   // now both beans A and B will be available...
   A a = ctx.getBean(A.class);
   B b = ctx.getBean(B.class);
}

Rappels de cycle de vie

L'annotation @Bean prend en charge la spécification de méthodes de rappel d'initialisation et de destruction arbitraires, tout comme les attributs init-method et destroy-method de Spring XML sur l'élément bean -

public class Foo {
   public void init() {
      // initialization logic
   }
   public void cleanup() {
      // destruction logic
   }
}
@Configuration
public class AppConfig {
   @Bean(initMethod = "init", destroyMethod = "cleanup" )
   public Foo foo() {
      return new Foo();
   }
}

Spécification de l'étendue du bean

La portée par défaut est singleton, mais vous pouvez la remplacer avec l'annotation @Scope comme suit -

@Configuration
public class AppConfig {
   @Bean
   @Scope("prototype")
   public Foo foo() {
      return new Foo();
   }
}