EJB - Penanganan Pengecualian
EJB adalah bagian dari aplikasi perusahaan yang biasanya didasarkan pada lingkungan terdistribusi. Jadi, selain dari pengecualian normal yang dapat terjadi, terdapat pengecualian seperti kegagalan komunikasi, izin keamanan, server down, dll.
Kontainer EJB mempertimbangkan pengecualian dalam dua cara -
Application Exception - Jika aturan bisnis dilanggar atau terjadi pengecualian saat menjalankan logika bisnis.
System Exception- Pengecualian apa pun, yang tidak disebabkan oleh logika bisnis atau kode bisnis. RuntimeException, RemoteException adalah SystemException. Misalnya, kesalahan selama pencarian EJB. RuntimeException, RemoteException adalah SystemException.
Bagaimana Kontainer EJB Menangani Pengecualian?
Kapan Application Exceptionterjadi, kontainer EJB mencegat pengecualian, tetapi mengembalikan hal yang sama ke klien sebagaimana adanya. Itu tidak mengembalikan transaksi kecuali ditentukan dalam kode dengan metode EJBContext.setRollBackOnly (). Kontainer EJB tidak membungkus pengecualian dalam kasus Pengecualian Aplikasi.
Kapan System Exceptionterjadi, wadah EJB mencegat pengecualian, mengembalikan transaksi dan memulai tugas pembersihan. Ini membungkus pengecualian ke dalam RemoteException dan melemparkannya ke klien.
Menangani Pengecualian Aplikasi
Pengecualian aplikasi umumnya dilemparkan dalam metode Sesi EJB karena ini adalah metode yang bertanggung jawab untuk menjalankan logika bisnis. Pengecualian aplikasi harus dideklarasikan dalam klausul lemparan metode bisnis dan harus dibuang jika logika bisnis gagal.
@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
...
public List<Book> getBooks() throws NoBookAvailableException {
List<Book> books =
entityManager.createQuery("From Books").getResultList();
if(books.size == 0)
throw NoBookAvailableException
("No Book available in library.");
return books;
}
...
}
Pengecualian Sistem Penanganan
Pengecualian sistem dapat terjadi kapan saja seperti pencarian penamaan gagal, kesalahan sql terjadi saat mengambil data. Dalam kasus seperti itu, pengecualian tersebut harus digabungkan di bawah EJBException dan dikembalikan ke klien.
@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
...
public List<Book> getBooks() {
try {
List<Book> books =
entityManager.createQuery("From Books").getResultList();
} catch (CreateException ce) {
throw (EJBException) new EJBException(ce).initCause(ce);
} catch (SqlException se) {
throw (EJBException) new EJBException(se).initCause(se);
}
return books;
}
...
}
Di sisi klien, tangani EJBException.
public class EJBTester {
private void testEntityEjb() {
...
try{
LibraryPersistentBeanRemote libraryBean =
LibraryPersistentBeanRemote)ctx.lookup("LibraryPersistentBean/remote");
List<Book> booksList = libraryBean.getBooks();
} catch(EJBException e) {
Exception ne = (Exception) e.getCause();
if(ne.getClass().getName().equals("SqlException")) {
System.out.println("Database error: "+ e.getMessage());
}
}
...
}
}