EJB - Injeksi Ketergantungan

Spesifikasi EJB 3.0 menyediakan penjelasan, yang dapat diterapkan pada bidang atau metode penyetel untuk memasukkan dependensi. EJB Container menggunakan registri JNDI global untuk menemukan ketergantungan. Anotasi berikut digunakan di EJB 3.0 untuk injeksi ketergantungan.

  • @EJB - digunakan untuk menginjeksi referensi EJB lainnya.

  • @Resource - digunakan untuk menginjeksi sumber data atau layanan tunggal seperti sessionContext, timerService, dll.

Langkah-langkah Menggunakan @EJB

@EJB dapat digunakan pada bidang atau metode dengan cara berikut -

public class LibraryMessageBean implements MessageListener {
   //dependency injection on field. 
   @EJB
   LibraryPersistentBeanRemote libraryBean;
   ...
}
public class LibraryMessageBean implements MessageListener {
  
   LibraryPersistentBeanRemote libraryBean;
   
   //dependency injection on method. 
   @EJB(beanName="com.tutorialspoint.stateless.LibraryPersistentBean")
   public void setLibraryPersistentBean(
   LibraryPersistentBeanRemote libraryBean)
   {
      this.libraryBean = libraryBean;
   }
   ...
}

Langkah-langkah untuk menggunakan @Resource

@Resource biasanya digunakan untuk menginjeksi EJB Container yang disediakan lajang.

public class LibraryMessageBean implements MessageListener {
   @Resource
   private MessageDrivenContext mdctx;  
   ...
}

Contoh Aplikasi

Mari kita buat aplikasi tes EJB untuk menguji Dependency Injection Service di EJB.

Langkah Deskripsi
1

Buat proyek dengan nama EjbComponent di bawah paket com.tutorialspoint.timer seperti yang dijelaskan di bab EJB - Buat Aplikasi .

2

Gunakan Kacang yang dibuat di bab EJB - Message Driven Bean . Jaga sisa file tidak berubah.

3

Bersihkan dan Bangun aplikasi untuk memastikan logika bisnis berfungsi sesuai persyaratan.

4

Terakhir, terapkan aplikasi dalam bentuk file jar di Server Aplikasi JBoss. Server Aplikasi JBoss akan dimulai secara otomatis jika belum dimulai.

5

Sekarang buat klien EJB, aplikasi berbasis konsol dengan cara yang sama seperti yang dijelaskan di bab EJB - Membuat Aplikasi di bawah topikCreate Client to access EJB.

Komponen EJBC (Modul EJB)

LibraryMessageBean.java

package com.tuturialspoint.messagebean;
 
import com.tutorialspoint.entity.Book;
import com.tutorialspoint.stateless.LibraryPersistentBeanRemote;
import javax.annotation.Resource;
import javax.ejb.ActivationConfigProperty;
import javax.ejb.EJB;
import javax.ejb.MessageDriven;
import javax.ejb.MessageDrivenContext;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.ObjectMessage;
 
@MessageDriven(
   name = "BookMessageHandler",
   activationConfig = {
      @ActivationConfigProperty( propertyName = "destinationType", 
                                 propertyValue = "javax.jms.Queue"),
      @ActivationConfigProperty( propertyName = "destination", 
                                 propertyValue ="/queue/BookQueue")
   }
)
public class LibraryMessageBean implements MessageListener {
 
   @Resource
   private MessageDrivenContext mdctx;  
 
   @EJB
   LibraryPersistentBeanRemote libraryBean;
 
   public LibraryMessageBean() {        
   }
 
   public void onMessage(Message message) {
      ObjectMessage objectMessage = null;
      try {
         objectMessage = (ObjectMessage) message;
         Book book = (Book) objectMessage.getObject(); 
         libraryBean.addBook(book);
 
      }catch (JMSException ex) {
         mdctx.setRollbackOnly();
      }       
   }   
}

EJBTester (Klien EJB)

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.entity.Book;
import com.tutorialspoint.stateless.LibraryPersistentBeanRemote;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.List;
import java.util.Properties;
import javax.jms.ObjectMessage;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.naming.InitialContext;
import javax.naming.NamingException;
 
public class EJBTester {
 
   BufferedReader brConsoleReader = null; 
   Properties props;
   InitialContext ctx;
   {
      props = new Properties();
      try {
         props.load(new FileInputStream("jndi.properties"));
      } catch (IOException ex) {
         ex.printStackTrace();
      }
      try {
         ctx = new InitialContext(props);            
      } catch (NamingException ex) {
         ex.printStackTrace();
      }
      brConsoleReader = 
      new BufferedReader(new InputStreamReader(System.in));
   }
   
   public static void main(String[] args) {
 
      EJBTester ejbTester = new EJBTester();
 
      ejbTester.testMessageBeanEjb();
   }
   
   private void showGUI() {
      System.out.println("**********************");
      System.out.println("Welcome to Book Store");
      System.out.println("**********************");
      System.out.print("Options \n1. Add Book\n2. Exit \nEnter Choice: ");
   }
   
   private void testMessageBeanEjb() {
 
      try {
         int choice = 1; 
         Queue queue = (Queue) ctx.lookup("/queue/BookQueue");
         QueueConnectionFactory factory =
         (QueueConnectionFactory) ctx.lookup("ConnectionFactory");
         QueueConnection connection =  factory.createQueueConnection();
         QueueSession session = connection.createQueueSession( 
         false, QueueSession.AUTO_ACKNOWLEDGE);
         QueueSender sender = session.createSender(queue);
 
         while (choice != 2) {
            String bookName;
            showGUI();
            String strChoice = brConsoleReader.readLine();
            choice = Integer.parseInt(strChoice);
            if (choice == 1) {
               System.out.print("Enter book name: ");
               bookName = brConsoleReader.readLine();
               Book book = new Book();
               book.setName(bookName);
               ObjectMessage objectMessage = 
               session.createObjectMessage(book);
               sender.send(objectMessage); 
            } else if (choice == 2) {
               break;
            }
         }
 
         LibraryPersistentBeanRemote libraryBean = 
         (LibraryPersistentBeanRemote)
		 ctx.lookup("LibraryPersistentBean/remote");
 
         List<Book> booksList = libraryBean.getBooks();
 
         System.out.println("Book(s) entered so far: " 
         + booksList.size());
         int i = 0;
         for (Book book:booksList) {
            System.out.println((i+1)+". " + book.getName());
            i++;
         }           
      } catch (Exception e) {
         System.out.println(e.getMessage());
         e.printStackTrace();
      }finally {
         try {
            if(brConsoleReader !=null) {
               brConsoleReader.close();
            }
         } catch (IOException ex) {
            System.out.println(ex.getMessage());
         }
      }
   }   
}

EJBTester melakukan tugas-tugas berikut -

  • Muat properti dari jndi.properties dan inisialisasi objek InitialContext.

  • Dalam metode testStatefulEjb (), pencarian jndi dilakukan dengan nama - "/ queue / BookQueue" untuk mendapatkan referensi antrian yang tersedia di Jboss. Kemudian pengirim dibuat menggunakan sesi antrian.

  • Kemudian pengguna diperlihatkan Antarmuka Pengguna toko perpustakaan dan dia diminta untuk memasukkan pilihan.

  • Jika pengguna memasukkan 1, sistem meminta nama buku dan pengirim mengirimkan nama buku ke antrian. Ketika wadah JBoss menerima pesan ini dalam antrian, itu memanggil metode onMessage pesan kacang kita. Kacang yang didorong pesan kami kemudian menyimpan buku menggunakan metode kacang addBook () sesi stateful. Session Bean mempertahankan buku dalam database melalui panggilan EntityManager.

  • Jika pengguna memasukkan 2, maka pencarian jndi lain dilakukan dengan nama - "LibraryStatefulSessionBean / remote" untuk mendapatkan objek bisnis jarak jauh (stateful EJB) lagi dan daftar buku selesai.

Jalankan Klien untuk Mengakses EJB

Temukan EJBTester.java di project explorer. Klik kanan pada kelas EJBTester dan pilihrun file.

Verifikasi keluaran berikut di konsol Netbeans.

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: Learn EJB
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 2
1. learn java
1. learn EJB
BUILD SUCCESSFUL (total time: 15 seconds)

Output yang ditunjukkan di atas menyatakan bahwa kacang yang digerakkan oleh pesan kami menerima pesan dan menyimpan buku dalam penyimpanan persisten dan buku diambil dari database.

Kacang yang didorong pesan kami menggunakan LibraryPersistentBean yang disuntikkan ke dalamnya menggunakan anotasi @EJB dan dalam kasus pengecualian, MessageDrivenContext, objek digunakan untuk mengembalikan transaksi.