EJB - Panggilan balik
Callback adalah mekanisme dimana siklus hidup kacang perusahaan dapat dicegat. Spesifikasi EJB 3.0 telah menetapkan callback yang metode penangan panggilan baliknya dibuat. EJB Container memanggil callback ini. Kita bisa mendefinisikan metode callback di kelas EJB itu sendiri atau di kelas terpisah. EJB 3.0 telah memberikan banyak penjelasan untuk callback.
Berikut adalah daftar anotasi panggilan balik untuk kacang tanpa kewarganegaraan -
Anotasi | Deskripsi |
---|---|
@Posting | Dipanggil saat kacang dibuat untuk pertama kalinya. |
@Tokopedia | Dipanggil ketika biji dikeluarkan dari kolam kacang atau dihancurkan. |
Berikut adalah daftar anotasi panggilan balik untuk kacang stateful -
Anotasi | Deskripsi |
---|---|
@Posting | Dipanggil saat kacang dibuat untuk pertama kalinya. |
@Tokopedia | Dipanggil ketika biji dikeluarkan dari kolam kacang atau dihancurkan. |
@Postingan | Dipanggil saat kacang dimuat untuk digunakan. |
@Pasivasi | Dipanggil ketika biji dimasukkan kembali ke kolam kacang. |
Berikut adalah daftar anotasi panggilan balik untuk kacang yang didorong pesan -
Anotasi | Deskripsi |
---|---|
@Posting | Dipanggil saat kacang dibuat untuk pertama kalinya. |
@Tokopedia | Dipanggil ketika biji dikeluarkan dari kolam kacang atau dihancurkan. |
Berikut adalah daftar anotasi panggilan balik untuk kacang entitas -
Anotasi | Deskripsi |
---|---|
@Tokopedia | Dipanggil ketika sebuah entitas dibuat dalam database. |
@Posters | Dipanggil setelah entitas dibuat dalam database. |
@Tokopedia | Dipanggil ketika entitas dihapus dari database. |
@Postingan | Dipanggil setelah entitas dihapus dari database. |
@Pembaruan | Dipanggil sebelum entitas diperbarui dalam database. |
@Tokopedia | Dipanggil saat rekaman diambil dari database dan dimuat ke entitas. |
Contoh Aplikasi
Mari kita buat aplikasi tes EJB untuk menguji berbagai callback di EJB.
Langkah | Deskripsi |
---|---|
1 | Buat proyek dengan nama EjbComponent di bawah paket com.tutorialspoint.stateless seperti yang dijelaskan di bab EJB - Membuat Aplikasi . Anda juga dapat menggunakan proyek yang dibuat di EJB - bab Ketekunan untuk bab ini untuk menambahkan berbagai callback ke EJB. |
2 | Buat LibrarySessionBean.java dan LibrarySessionBeanRemote seperti yang dijelaskan di bab EJB - Buat Aplikasi . Jaga sisa file tidak berubah. |
3 | Gunakan Kacang yang dibuat di EJB - bab Ketekunan . Tambahkan metode callback seperti yang ditunjukkan di bawah ini. Jaga sisa file tidak berubah. |
4 | Buat bookCallbackListener kelas java di bawah paket com.tutorialspoint.callback . Kelas ini akan mendemonstrasikan pemisahan metode callback. |
5 | Bersihkan dan Bangun aplikasi untuk memastikan logika bisnis berfungsi sesuai persyaratan. |
6 | Terakhir, terapkan aplikasi dalam bentuk file jar di JBoss Application Server. Server Aplikasi JBoss akan dimulai secara otomatis jika belum dimulai. |
7 | 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)
BookCallbackListener.java
package com.tutorialspoint.callback;
import javax.persistence.PrePersist;
import javax.persistence.PostLoad;
import javax.persistence.PostPersist;
import javax.persistence.PostRemove;
import javax.persistence.PostUpdate;
import javax.persistence.PreRemove;
import javax.persistence.PreUpdate;
import com.tutorialspoint.entity.Book;
public class BookCallbackListener {
@PrePersist
public void prePersist(Book book) {
System.out.println("BookCallbackListener.prePersist:"
+ "Book to be created with book id: "+book.getId());
}
@PostPersist
public void postPersist(Object book) {
System.out.println("BookCallbackListener.postPersist::"
+ "Book created with book id: "+((Book)book).getId());
}
@PreRemove
public void preRemove(Book book) {
System.out.println("BookCallbackListener.preRemove:"
+ " About to delete Book: " + book.getId());
}
@PostRemove
public void postRemove(Book book) {
System.out.println("BookCallbackListener.postRemove::"
+ " Deleted Book: " + book.getId());
}
@PreUpdate
public void preUpdate(Book book) {
System.out.println("BookCallbackListener.preUpdate::"
+ " About to update Book: " + book.getId());
}
@PostUpdate
public void postUpdate(Book book) {
System.out.println("BookCallbackListener.postUpdate::"
+ " Updated Book: " + book.getId());
}
@PostLoad
public void postLoad(Book book) {
System.out.println("BookCallbackListener.postLoad::"
+ " Loaded Book: " + book.getId());
}
}
Book.java
package com.tutorialspoint.entity;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EntityListeners;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="books")
public class Book implements Serializable{
private int id;
private String name;
public Book() {
}
@Id
@GeneratedValue(strategy= GenerationType.IDENTITY)
@Column(name="id")
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
LibraryStatefulSessionBean.java
package com.tutorialspoint.stateful;
import java.util.ArrayList;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.ejb.PostActivate;
import javax.ejb.PrePassivate;
import javax.ejb.Stateful;
@Stateful
public class LibraryStatefulSessionBean
implements LibraryStatefulSessionBeanRemote {
List<String> bookShelf;
public LibraryStatefulSessionBean() {
bookShelf = new ArrayList<String>();
}
public void addBook(String bookName) {
bookShelf.add(bookName);
}
public List<String> getBooks() {
return bookShelf;
}
@PostConstruct
public void postConstruct() {
System.out.println("LibraryStatefulSessionBean.postConstruct::"
+ " bean created.");
}
@PreDestroy
public void preDestroy() {
System.out.println("LibraryStatefulSessionBean.preDestroy:"
+ " bean removed.");
}
@PostActivate
public void postActivate() {
System.out.println("LibraryStatefulSessionBean.postActivate:"
+ " bean activated.");
}
@PrePassivate
public void prePassivate() {
System.out.println("LibraryStatefulSessionBean.prePassivate:"
+ " bean passivated.");
}
}
LibraryStatefulSessionBeanRemote.java
package com.tutorialspoint.stateful;
import java.util.List;
import javax.ejb.Remote;
@Remote
public interface LibraryStatefulSessionBeanRemote {
void addBook(String bookName);
List getBooks();
}
LibraryPersistentBean.java
package com.tutorialspoint.stateless;
import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
@Stateless
public class LibraryPersistentBean
implements LibraryPersistentBeanRemote {
public LibraryPersistentBean() {}
@PersistenceContext(unitName="EntityEjbPU")
private EntityManager entityManager;
public void addBook(Book book) {
entityManager.persist(book);
}
public List<Book> getBooks() {
return entityManager.createQuery("From Book")
.getResultList();
}
@PostConstruct
public void postConstruct() {
System.out.println("postConstruct:: LibraryPersistentBean session bean"
+ " created with entity Manager object: ");
}
@PreDestroy
public void preDestroy() {
System.out.println("preDestroy: LibraryPersistentBean session"
+ " bean is removed ");
}
}
LibraryPersistentBeanRemote.java
package com.tutorialspoint.stateless;
import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Remote;
@Remote
public interface LibraryPersistentBeanRemote {
void addBook(Book bookName);
List<Book> getBooks();
}
Segera setelah Anda menerapkan proyek EjbComponent di JBOSS, perhatikan log jboss.
JBoss secara otomatis membuat entri JNDI untuk kacang sesi kami - LibraryPersistentBean/remote.
Kami akan menggunakan string pencarian ini untuk mendapatkan jenis objek bisnis jarak jauh - com.tutorialspoint.stateless.LibraryPersistentBeanRemote
Output Log Server Aplikasi JBoss
...
16:30:01,401 INFO [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
LibraryPersistentBean/remote-com.tutorialspoint.stateless.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibraryPersistentBean,service=EJB3
16:30:02,723 INFO [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBeanRemote ejbName: LibraryPersistentBean
...
EJBTester (Klien EJB)
jndi.properties
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=localhost
Properti ini digunakan untuk menginisialisasi objek InitialContext dari layanan penamaan java.
Objek InitialContext akan digunakan untuk mencari kacang sesi stateless.
EJBTester.java
package com.tutorialspoint.test;
import com.tutorialspoint.stateful.LibrarySessionBeanRemote;
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.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.testEntityEjb();
}
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 testEntityEjb() {
try {
int choice = 1;
LibraryPersistentBeanRemote libraryBean =
(LibraryPersistentBeanRemote)
ctx.lookup("LibraryPersistentBean/remote");
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);
libraryBean.addBook(book);
} else if (choice == 2) {
break;
}
}
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 testStatelessEjb (), pencarian jndi dilakukan dengan nama - "LibrarySessionBean / remote" untuk mendapatkan objek bisnis jarak jauh (stateless EJB).
Kemudian pengguna ditunjukkan Antarmuka Pengguna toko perpustakaan dan dia diminta untuk memasukkan pilihan.
Jika pengguna memasukkan 1, sistem meminta nama buku dan menyimpan buku menggunakan metode stateless bean addBook (). Session Bean menyimpan buku di database.
Jika pengguna memasuki 2, sistem mengambil buku menggunakan metode stateless bean getBooks () metode dan keluar.
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 Java
**********************
Welcome to Book Store
**********************
Options
1. Add Book
2. Exit
Enter Choice: 2
Book(s) entered so far: 1
1. Learn Java
BUILD SUCCESSFUL (total time: 13 seconds)
Output Log Server Aplikasi JBoss
Anda dapat menemukan entri panggilan balik berikut di log JBoss
14:08:34,293 INFO [STDOUT] postConstruct:: LibraryPersistentBean session bean created with entity Manager object
...
16:39:09,484 INFO [STDOUT] BookCallbackListener.prePersist:: Book to be created with book id: 0
16:39:09,531 INFO [STDOUT] BookCallbackListener.postPersist:: Book created with book id: 1
16:39:09,900 INFO [STDOUT] BookCallbackListener.postLoad:: Loaded Book: 1
...