Spring - Konfigurasi Berbasis Java

Sejauh ini Anda telah melihat bagaimana kami mengkonfigurasi Spring beans menggunakan file konfigurasi XML. Jika Anda merasa nyaman dengan konfigurasi XML, maka sebenarnya tidak perlu mempelajari cara melanjutkan dengan konfigurasi berbasis Java karena Anda akan mendapatkan hasil yang sama menggunakan salah satu konfigurasi yang tersedia.

Opsi konfigurasi berbasis Java memungkinkan Anda untuk menulis sebagian besar konfigurasi Spring Anda tanpa XML tetapi dengan bantuan beberapa anotasi berbasis Java yang dijelaskan dalam bab ini.

@Konfigurasi & Anotasi @Bean

Menganotasi kelas dengan @Configurationmenunjukkan bahwa kelas dapat digunakan oleh wadah Spring IoC sebagai sumber definisi kacang. Itu@Beanannotation memberitahu Spring bahwa metode yang dianotasi dengan @Bean akan mengembalikan objek yang harus didaftarkan sebagai kacang dalam konteks aplikasi Spring. Kelas @Configuration yang paling sederhana adalah sebagai berikut -

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

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

Kode di atas akan sama dengan konfigurasi XML berikut -

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

Di sini, nama metode dianotasi dengan @Bean berfungsi sebagai ID kacang dan membuat serta mengembalikan kacang sebenarnya. Kelas konfigurasi Anda dapat memiliki deklarasi untuk lebih dari satu @Bean. Setelah kelas konfigurasi Anda ditentukan, Anda dapat memuat dan menyediakannya ke container Spring menggunakan AnnotationConfigApplicationContext sebagai berikut -

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

Anda dapat memuat berbagai kelas konfigurasi sebagai berikut -

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();
}

Contoh

Mari kita memiliki IDE Eclipse yang berfungsi dan mengambil langkah-langkah berikut untuk membuat aplikasi Spring -

Langkah Deskripsi
1 Buat proyek dengan nama SpringExample dan buat paket com.tutorialspoint di bawahsrc folder dalam proyek yang dibuat.
2 Tambahkan library Spring yang diperlukan menggunakan opsi Add External JARs seperti yang dijelaskan di bab Contoh Spring Hello World .
3 Karena Anda menggunakan anotasi berbasis Java, maka Anda juga perlu menambahkan CGLIB.jar dari direktori instalasi Java dan pustaka ASM.jar yang dapat diunduh dari asm.ow2.org .
4 Buat kelas Java HelloWorldConfig , HelloWorld dan MainApp di bawah paket com.tutorialspoint .
5 Langkah terakhir adalah membuat konten dari semua file Java dan file Konfigurasi Bean dan menjalankan aplikasi seperti yang dijelaskan di bawah ini.

Berikut adalah konten dari HelloWorldConfig.java mengajukan

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

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

Berikut adalah konten dari HelloWorld.java mengajukan

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);
   }
}

Berikut ini adalah konten dari MainApp.java mengajukan

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();
   }
}

Setelah Anda selesai membuat semua file sumber dan menambahkan pustaka tambahan yang diperlukan, biarkan kami menjalankan aplikasi. Anda harus mencatat bahwa tidak ada file konfigurasi yang diperlukan. Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan mencetak pesan berikut -

Your Message : Hello World!

Menyuntikkan Dependensi Bean

Ketika @Beans memiliki ketergantungan satu sama lain, menyatakan bahwa ketergantungan itu sesederhana memiliki satu metode kacang memanggil yang lain sebagai berikut -

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();
   }
}

Di sini, kacang foo menerima referensi ke bar melalui injeksi konstruktor. Sekarang mari kita lihat contoh kerja lainnya.

Contoh

Mari kita memiliki IDE Eclipse yang berfungsi dan mengambil langkah-langkah berikut untuk membuat aplikasi Spring -

Langkah Deskripsi
1 Buat proyek dengan nama SpringExample dan buat paket com.tutorialspoint di bawahsrc folder dalam proyek yang dibuat.
2 Tambahkan library Spring yang diperlukan menggunakan opsi Add External JARs seperti yang dijelaskan di bab Contoh Spring Hello World .
3 Karena Anda menggunakan anotasi berbasis Java, maka Anda juga perlu menambahkan CGLIB.jar dari direktori instalasi Java dan pustaka ASM.jar yang dapat diunduh dari asm.ow2.org .
4 Buat kelas Java TextEditorConfig , TextEditor , SpellChecker dan MainApp di bawah paket com.tutorialspoint .
5 Langkah terakhir adalah membuat konten dari semua file Java dan file Konfigurasi Bean dan menjalankan aplikasi seperti yang dijelaskan di bawah ini.

Berikut adalah konten dari TextEditorConfig.java mengajukan

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( );
   }
}

Berikut adalah konten dari TextEditor.java mengajukan

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();
   }
}

Berikut adalah konten file kelas dependen lainnya SpellChecker.java

package com.tutorialspoint;

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

Berikut ini adalah konten dari MainApp.java mengajukan

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();
   }
}

Setelah Anda selesai membuat semua file sumber dan menambahkan pustaka tambahan yang diperlukan, biarkan kami menjalankan aplikasi. Anda harus mencatat bahwa tidak ada file konfigurasi yang diperlukan. Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan mencetak pesan berikut -

Inside SpellChecker constructor.
Inside TextEditor constructor.
Inside checkSpelling.

Anotasi @Iport

Itu @Importanotasi memungkinkan untuk memuat definisi @Bean dari kelas konfigurasi lain. Pertimbangkan kelas ConfigA sebagai berikut -

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

Anda dapat mengimpor deklarasi Bean di atas dalam Deklarasi Bean lainnya sebagai berikut -

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

Sekarang, daripada perlu menentukan ConfigA.class dan ConfigB.class saat membuat instance konteks, hanya ConfigB yang perlu disediakan sebagai berikut -

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);
}

Lifecycle Callbacks

Anotasi @Bean mendukung penentuan inisialisasi arbitrer dan metode callback pemusnahan, seperti atribut metode init dan metode perusakan Spring XML pada elemen kacang -

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();
   }
}

Menentukan Cakupan Bean

Cakupan defaultnya adalah tunggal, tetapi Anda dapat menimpanya dengan anotasi @Scope sebagai berikut -

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