ईजेबी - त्वरित गाइड

EJB का मतलब है Enterprise Java Beans। EJB एक J2EE प्लेटफॉर्म का एक अनिवार्य हिस्सा है। J2EE प्लेटफ़ॉर्म में उद्यम स्तर के अनुप्रयोगों के लिए बहु-स्तरीय, वितरित और अत्यधिक लेनदेन सुविधाओं को प्रदान करने के लिए घटक आधारित वास्तुकला है।

EJB मजबूती, उच्च मापनीयता और उच्च प्रदर्शन को देखते हुए घटक आधारित उद्यम अनुप्रयोगों को विकसित और तैनात करने के लिए एक वास्तुकला प्रदान करता है। एक EJB एप्लिकेशन को J2EE 1.3 मानक विनिर्देशन के अनुरूप किसी भी एप्लिकेशन सर्वर पर तैनात किया जा सकता है।

हम इस ट्यूटोरियल में EJB 3.0 पर विस्तार से चर्चा करेंगे।

प्रकार

ईजेबी मुख्य रूप से तीन श्रेणियों में विभाजित है; निम्न तालिका संक्षिप्त विवरण के साथ उनके नामों को सूचीबद्ध करती है -

S.No टाइप और विवरण
1

Session Bean

एक सत्र के लिए सत्र बीन किसी विशेष उपयोगकर्ता का डेटा संग्रहीत करता है। यह हो सकता हैstateful या stateless। यह इकाई बीन की तुलना में कम संसाधन गहन है। उपयोगकर्ता सत्र समाप्त होते ही सत्र बीन नष्ट हो जाता है।

2

Entity Bean

Entity beansलगातार डेटा स्टोरेज का प्रतिनिधित्व करें। उपयोगकर्ता डेटा को इकाई बीन्स के माध्यम से डेटाबेस में सहेजा जा सकता है और बाद में इकाई बीन में डेटाबेस से पुनर्प्राप्त किया जा सकता है।

3

Message Driven Bean

Message driven beansJMS (जावा मैसेजिंग सर्विस) के संदर्भ में उपयोग किया जाता है। संदेश प्रेरित बीन्स बाहरी संस्थाओं से जेएमएस संदेशों का उपभोग कर सकते हैं और तदनुसार कार्य कर सकते हैं।

लाभ

EJB के महत्वपूर्ण लाभ निम्नलिखित हैं -

  • बड़े पैमाने पर उद्यम स्तर के अनुप्रयोग का सरलीकृत विकास।

  • एप्लिकेशन सर्वर / EJB कंटेनर लेन-देन से निपटने, लॉगिंग, लोड संतुलन, हठ तंत्र, अपवाद हैंडलिंग, और इतने पर जैसे सिस्टम स्तर की अधिकांश सेवाएं प्रदान करता है। डेवलपर को केवल एप्लिकेशन के व्यावसायिक तर्क पर ध्यान केंद्रित करना होगा।

  • EJB कंटेनर EJB उदाहरणों के जीवन चक्र का प्रबंधन करता है, इस प्रकार डेवलपर को EJB ऑब्जेक्ट बनाने / हटाने के बारे में चिंता करने की आवश्यकता नहीं है।

EJB जावा के लिए एक ढांचा है, इसलिए सबसे पहली आवश्यकता है एक Jएवा Development Kयह (JDK) आपकी मशीन में स्थापित है।

व्यवस्था की आवश्यकता

JDK 1.5 या ऊपर।
याद कोई न्यूनतम आवश्यकता नहीं।
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं।
ऑपरेटिंग सिस्टम कोई न्यूनतम आवश्यकता नहीं।

चरण 1 - अपने सिस्टम में जावा इंस्टॉलेशन को सत्यापित करें

अब कंसोल खोलें और निम्नलिखित को निष्पादित करें java आदेश।

ओएस टास्क आदेश
खिड़कियाँ कमांड कंसोल खोलें c: \> java -version
लिनक्स कमांड टर्मिनल खोलें $ जावा -अविवर्तन
मैक टर्मिनल खोलें मशीन: ~ joseph $ java -version

आइए सभी ऑपरेटिंग सिस्टम के लिए आउटपुट को सत्यापित करें -

ओएस उत्पादन
खिड़कियाँ

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b11)

जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर वीएम (23.21-b01, मिश्रित मोड का निर्माण)

लिनक्स

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b11)

जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर वीएम (23.21-b01, मिश्रित मोड का निर्माण)

मैक

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b11)

जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर वीएम (23.21-b01, मिश्रित मोड का निर्माण)

यदि आपके पास जावा स्थापित नहीं है, तो www.oracle.com से जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) स्थापित करें । हम मान रहे हैं कि इस ट्यूटोरियल के लिए जावा 1.6.0_21 इंस्टॉल किए गए संस्करण के रूप में है।

चरण 2 - जावा पर्यावरण सेट करें

ठीक JAVA_HOMEपरिवेश चर आधार बिंदु स्थान को इंगित करने के लिए जहां जावा आपके सिस्टम पर स्थापित है। उदाहरण के लिए,

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर JAVA_HOME को C: \ Program Files \ Java \ jdk1.6.0_21 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान
मैक निर्यात JAVA_HOME = / लाइब्रेरी / जावा / होम

सिस्टम पथ में जावा संकलक स्थान को जोड़ें।

ओएस उत्पादन
खिड़कियाँ स्ट्रिंग को संलग्न करें; C: \ Program Files \ Java \ jdk1.6.0_21 \ bin सिस्टम चर के अंत में, पथ।
लिनक्स निर्यात पथ =$PATH:$JAVA_HOME / bin /
मैक आवश्यक नहीं

जावा इंस्टॉलेशन का उपयोग करके सत्यापित करें java -version ऊपर बताया गया कमांड।

चरण 3 - डाउनलोड और स्थापित NetBeans IDE

NetBeans IDE का नवीनतम संस्करण netbeans.org से डाउनलोड करें । इस ट्यूटोरियल को लिखने के समय, मैंने नेटबीन्स 7.3 डाउनलोड किया था जो JDK 1.7 के साथ बंडल किया गया है जो निम्नलिखित लिंक www.oracle.com का उपयोग करता है।

ओएस संस्थापक का नाम
खिड़कियाँ नेटबीन्स 7.3
लिनक्स नेटबीन्स 7.3
मैक नेटबीन्स 7.3

चरण 4 - सेटअप JBoss अनुप्रयोग सर्वर

आप JBoss सर्वर के नवीनतम संस्करण को www.jboss.org से डाउनलोड कर सकते हैं । प्लेटफॉर्म के अनुसार संग्रह डाउनलोड करें। अपनी मशीन पर किसी भी स्थान पर Jboss निकालें।

ओएस फ़ाइल का नाम
खिड़कियाँ jboss-5.1.0.GA-jdk6.zip
लिनक्स jboss-5.1.0.GA-src.tar.gz
मैक jboss-5.1.0.GA-src.tar.gz

चरण 5 - नेटबीन्स को जेईई प्लगइन्स कॉन्फ़िगर करें

टूल्स> प्लगइन्स का उपयोग करके प्लगइन विंडो खोलें। "उपलब्ध प्लगइन" टैब खोलें और "जावा वेब और ईई" श्रेणी के तहत "जावा ईई बेस" और "ईजेबी और ईएआर" चुनें। इंस्टॉल बटन पर क्लिक करें। Netbeans संबंधित प्लगइन्स को डाउनलोड और इंस्टॉल करेगा। "इंस्टॉल" टैब का उपयोग करके प्लगइन्स की स्थापना को सत्यापित करें (जैसा कि नीचे दी गई छवि में दिखाया गया है)।

चरण 6 - नेटबीन्स में JBoss सर्वर कॉन्फ़िगर करें

सर्विसेज टैब पर जाएं और नया सर्वर जोड़ने के लिए सर्वर पर राइट क्लिक करें।

जोड़ें सर्वर इंस्टेंस विज़ार्ड खुल जाएगा। JBoss का चयन करें और अगले चरण में नेटबीन्स में सर्वर को कॉन्फ़िगर करने के लिए प्रासंगिक विवरण दर्ज करें।

एक बार सब कुछ कॉन्फ़िगर हो जाने के बाद, आपको निम्न स्क्रीन दिखाई देगी।

चरण 7 - डेटाबेस सर्वर स्थापित करें (PostGreSql)

से PostgreSQL डेटाबेस सर्वर का नवीनतम संस्करण डाउनलोड www.postgresql.org । इस ट्यूटोरियल के लेखन के समय, मैंने PostGreSql 9.2 डाउनलोड किया

ओएस संस्थापक का नाम
खिड़कियाँ PostGreSql 9.2
लिनक्स PostGreSql 9.2
मैक PostGreSql 9.2

एक सरल EJB मॉड्यूल बनाने के लिए, हम "नए प्रोजेक्ट" विज़ार्ड NetBeans का उपयोग करेंगे। नीचे दिए गए उदाहरण में, हम घटक नामक एक EJB मॉड्यूल परियोजना बनाएंगे।

प्रोजेक्ट बनाएं

NetBeans IDE में, चुनें File > New Project >। आपको निम्न स्क्रीन दिखाई देगी

श्रेणी के तहत प्रोजेक्ट प्रकार का चयन करें Java EE, परियोजना का प्रकार EJB Module। क्लिकNext >बटन। आपको निम्न स्क्रीन दिखाई देगी।

प्रोजेक्ट का नाम और स्थान दर्ज करें। क्लिकNext >बटन। आपको निम्न स्क्रीन दिखाई देगी।

के रूप में सर्वर का चयन करें JBoss Application Server। क्लिकFinishबटन। आप NetBeans द्वारा बनाई गई निम्न परियोजना देखेंगे।

एक नमूना EJB बनाएँ

एक सरल EJB बनाने के लिए, हम NetBeans "न्यू" विज़ार्ड का उपयोग करेंगे। नीचे दिए गए उदाहरण में, हम EjbComponent प्रोजेक्ट के तहत एक अज्ञात EJB क्लास लायब्रेरीSessionBean नाम से बनाएंगे।

प्रोजेक्ट एक्सप्लोरर विंडो में प्रोजेक्ट EjbComponent चुनें और उस पर राइट क्लिक करें। चुनते हैं,New > Session Bean। आप देखेंगेNew Session Bean जादूगर।

सत्र बीन नाम और पैकेज नाम दर्ज करें। क्लिकFinishबटन। आप नेटबीन्स द्वारा बनाई गई निम्नलिखित ईजेबी कक्षाएं देखेंगे।

  • LibrarySessionBean - स्टेटलेस सेशन बीन

  • LibrarySessionBeanLocal - सत्र बीन के लिए स्थानीय इंटरफ़ेस

मैं स्थानीय इंटरफ़ेस को दूरस्थ इंटरफ़ेस में बदल रहा हूं क्योंकि हम अपने EJB को कंसोल आधारित एप्लिकेशन में एक्सेस करने जा रहे हैं। रिमोट / लोकल इंटरफ़ेस का उपयोग उन व्यापारिक विधियों को उजागर करने के लिए किया जाता है जिन्हें एक EJB को लागू करना है।

LibrarySessionBeanLocal का नाम बदलकर LibrarySessionBeanRemote और LibrarySessionBean लागू किया गया है।

LibrarySessionBeanRemote

package com.tutorialspoint.stateless;
 
import java.util.List;
import javax.ejb.Remote;
 
@Remote
public interface LibrarySessionBeanRemote {
   void addBook(String bookName);
   List getBooks();
}

LibrarySessionBean

package com.tutorialspoint.stateless;
 
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;
 
@Stateless
public class LibrarySessionBean implements LibrarySessionBeanRemote {
   
   List<String> bookShelf;    
   
   public LibrarySessionBean() {
      bookShelf = new ArrayList<String>();
   }
    
   public void addBook(String bookName) {
      bookShelf.add(bookName);
   }    
 
   public List<String> getBooks() {
      return bookShelf;
   }
}

प्रोजेक्ट बनाएं

  • प्रोजेक्ट एक्सप्लोरर विंडो में EjbComponent प्रोजेक्ट चुनें।
  • संदर्भ मेनू खोलने के लिए उस पर राइट क्लिक करें।
  • स्वच्छ और निर्माण का चयन करें।

आपको NetBeans कंसोल आउटपुट में निम्न आउटपुट दिखाई देगा।

ant -f C:\\EJB\\EjbComponent clean dist
init:
undeploy-clean:
deps-clean:
Deleting directory C:\EJB\EjbComponent\build
Deleting directory C:\EJB\EjbComponent\dist
clean:
init:
deps-jar:
Created dir: C:\EJB\EjbComponent\build\classes
Copying 3 files to C:\EJB\EjbComponent\build\classes\META-INF
Created dir: C:\EJB\EjbComponent\build\empty
Created dir: C:\EJB\EjbComponent\build\generated-sources\ap-source-output
Compiling 2 source files to C:\EJB\EjbComponent\build\classes
warning: [options] bootstrap class path not set in conjunction with -source 1.6
Note: C:\EJB\EjbComponent\src\java\com\tutorialspoint\stateless
\LibraryPersistentBean.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
1 warning
compile:
library-inclusion-in-archive:
Created dir: C:\EJB\EjbComponent\dist
Building jar: C:\EJB\EjbComponent\dist\EjbComponent.jar
dist:
BUILD SUCCESSFUL (total time: 3 seconds)

अनुप्रयोग सर्वर प्रारंभ करें

  • सर्वर विंडो में सर्वर के अंतर्गत JBoss एप्लिकेशन सर्वर का चयन करें।
  • संदर्भ मेनू खोलने के लिए उस पर राइट क्लिक करें।
  • प्रारंभ का चयन करें।

आपको NetBeans में निम्न आउटपुट, JBoss एप्लिकेशन सर्वर के तहत आउटपुट दिखाई देगा।

Calling C:\jboss-5.1.0.GA\bin\run.conf.bat
=========================================================================
 
   JBoss Bootstrap Environment
 
   JBOSS_HOME: C:\jboss-5.1.0.GA
 
   JAVA: C:\Program Files (x86)\Java\jdk1.6.0_21\bin\java
 
   JAVA_OPTS: -Dprogram.name=run.bat -Xms128m -Xmx512m -server
 
   CLASSPATH: C:\jboss-5.1.0.GA\bin\run.jar
 
=========================================================================
 
16:25:50,062 INFO  [ServerImpl] Starting JBoss (Microcontainer)...
16:25:50,062 INFO  [ServerImpl] Release ID: JBoss 
   [The Oracle] 5.1.0.GA (build: SVNTag=JBoss_5_1_0_GA date=200905221634)
...
 
16:26:40,420 INFO  [TomcatDeployment] deploy, ctxPath=/admin-console
16:26:40,485 INFO  [config] Initializing Mojarra (1.2_12-b01-FCS) for context '/admin-console'
16:26:42,362 INFO  [TomcatDeployment] deploy, ctxPath=/
16:26:42,406 INFO  [TomcatDeployment] deploy, ctxPath=/jmx-console
16:26:42,471 INFO  [Http11Protocol] Starting Coyote HTTP/1.1 on http-127.0.0.1-8080
16:26:42,487 INFO  [AjpProtocol] Starting Coyote AJP/1.3 on ajp-127.0.0.1-8009
16:26:42,493 INFO  [ServerImpl] JBoss (Microcontainer) 
   [5.1.0.GA (build: SVNTag=JBoss_5_1_0_GA date=200905221634)] Started in 52s:427ms

परियोजना तैनात करें

  • प्रोजेक्ट एक्सप्लोरर विंडो में EjbComponent प्रोजेक्ट चुनें।
  • संदर्भ मेनू खोलने के लिए उस पर राइट क्लिक करें।
  • Deploy चुनें।

आपको NetBeans कंसोल आउटपुट में निम्न आउटपुट दिखाई देगा।

ant -f C:\\EJB\\EjbComponent -DforceRedeploy=true -Ddirectory.deployment.supported=false -Dnb.wait.for.caches=true run
init:
deps-jar:
compile:
library-inclusion-in-archive:
Building jar: C:\EJB\EjbComponent\dist\EjbComponent.jar
dist-directory-deploy:
pre-run-deploy:
Checking data source definitions for missing JDBC drivers...
Distributing C:\EJB\EjbComponent\dist\EjbComponent.jar to [org.jboss.deployment.spi.LocalhostTarget@1e4f84ee]
Deploying C:\EJB\EjbComponent\dist\EjbComponent.jar
Application Deployed
Operation start started
Operation start completed
post-run-deploy:
run-deploy:
run:
BUILD SUCCESSFUL (total time: 2 seconds)

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

16:30:00,963 INFO  [DeployHandler] Begin start, [EjbComponent.jar]
...
16:30:01,233 INFO  [Ejb3DependenciesDeployer] Encountered deployment AbstractVFSDeploymentContext@12038795{vfszip:/C:/jboss-5.1.0.GA/server/default/deploy/EjbComponent.jar/}
...
16:30:01,281 INFO  [JBossASKernel]    jndi:LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote
16:30:01,281 INFO  [JBossASKernel]    Class:com.tutorialspoint.stateless.LibrarySessionBeanRemote
16:30:01,281 INFO  [JBossASKernel]    jndi:LibrarySessionBean/remote
16:30:01,281 INFO  [JBossASKernel]  Added bean(jboss.j2ee:jar=EjbComponent.jar,name=
LibrarySessionBean,service=EJB3) to KernelDeployment of: EjbComponent.jar
16:30:01,282 INFO  [JBossASKernel] installing bean: jboss.j2ee:jar=EjbComponent.jar,name=BookMessageHandler,service=EJB3
16:30:01,282 INFO  [JBossASKernel]   with dependencies:
16:30:01,282 INFO  [JBossASKernel]   and demands:
16:30:01,282 INFO  [JBossASKernel]    jboss.ejb:service=EJBTimerService
...
16:30:01,283 INFO  [EJB3EndpointDeployer] Deploy 
AbstractBeanMetaData@5497cb{name=jboss.j2ee:jar=EjbComponent.jar, 
name=LibrarySessionBean, service=EJB3_endpoint bean=org.jboss.ejb3.endpoint.deployers.impl.EndpointImpl properties=[container] constructor=null autowireCandidate=true}
...
16:30:01,394 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:01,395 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBean ejbName: LibrarySessionBean
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
   LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBean ejbName: LibrarySessionBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
 
   LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
   LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface

EJB को एक्सेस करने के लिए क्लाइंट बनाएं

  • NetBeans IDE में, चुनें File > New Project >

  • श्रेणी के तहत प्रोजेक्ट प्रकार का चयन करें Java, परियोजना का प्रकार Java Application। Next> बटन पर क्लिक करें

  • प्रोजेक्ट का नाम और स्थान दर्ज करें। क्लिकFinish >बटन। हमने नाम EjbTester चुना है।

  • प्रोजेक्ट एक्सप्लोरर विंडो में प्रोजेक्ट के नाम पर राइट क्लिक करें। चुनते हैंproperties

  • उपयोग करने वाले पुस्तकालयों के तहत पहले बनाई गई EJB घटक परियोजना जोड़ें Add Project में बटन compile टैब।

  • का उपयोग कर jboss पुस्तकालयों जोड़ें Add jar/folder में बटन compileटैब। Jboss पुस्तकालयों <jboss स्थापना फ़ोल्डर >> क्लाइंट फ़ोल्डर में स्थित हो सकता है।

EjbTester कहते हैं कि परियोजना के तहत jndi.properties बनाएँ।

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

इसके तहत पैकेज com.tutorialspoint.test और EJBTester.java क्लास बनाएं।

EJBTester.java

package com.tutorialspoint.test;
 
import com.tutorialspoint.stateless.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.testStatelessEjb();
   }
   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 testStatelessEjb() {
      try {
         int choice = 1; 
         LibrarySessionBeanRemote libraryBean = 
         (LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/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();                    
               libraryBean.addBook(bookName);          
            }else if (choice == 2) {
               break;
            }
         }
         List<String> booksList = libraryBean.getBooks();
         System.out.println("Book(s) entered so far: " + booksList.size());
         for (int i = 0; i < booksList.size(); ++i) {
            System.out.println((i+1)+". " + booksList.get(i));
         }
         LibrarySessionBeanRemote libraryBean1 = 
         (LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/remote");
         List<String> booksList1 = libraryBean1.getBooks();
         System.out.println(
            "***Using second lookup to get library stateless object***");
         System.out.println(
            "Book(s) entered so far: " + booksList1.size());
         for (int i = 0; i < booksList1.size(); ++i) {
            System.out.println((i+1)+". " + booksList1.get(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());
         }
      }
   }  
}

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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
***Using second lookup to get library stateless object***
Book(s) entered so far: 0
BUILD SUCCESSFUL (total time: 13 seconds)

निम्नलिखित अध्यायों में, हम इस पूर्ण EJB अनुप्रयोग के कई पहलुओं को शामिल करेंगे।

एक स्टेटलेस सेशन बीन एंटरप्राइज बीन का एक प्रकार है, जो आम तौर पर स्वतंत्र संचालन करने के लिए उपयोग किया जाता है। अपने नाम के अनुसार एक स्टेटलेस सेशन बीन के पास कोई संबद्ध ग्राहक स्थिति नहीं है, लेकिन यह अपनी आवृत्ति स्थिति को संरक्षित कर सकता है। EJB कंटेनर आम तौर पर कुछ स्टेटलेस बीन की वस्तुओं का एक पूल बनाता है और क्लाइंट के अनुरोध को संसाधित करने के लिए इन वस्तुओं का उपयोग करता है। पूल के कारण, उदाहरण चर मानों को लुकअप / मेथड कॉल में समान होने की गारंटी नहीं है।

एक स्टेटलेस ईजेबी बनाने के लिए कदम

निम्नांकित EJB बनाने के लिए आवश्यक कदम निम्नलिखित हैं -

  • व्यावसायिक विधियों को उजागर करने वाला एक दूरस्थ / स्थानीय इंटरफ़ेस बनाएं।

  • इस इंटरफ़ेस का उपयोग EJB क्लाइंट एप्लिकेशन द्वारा किया जाएगा।

  • @Local एनोटेशन का उपयोग करें, यदि EJB क्लाइंट उसी वातावरण में है जहाँ EJB सत्र बीन को तैनात किया जाना है।

  • @Remote एनोटेशन का उपयोग करें, यदि EJB क्लाइंट अलग वातावरण में है जहाँ EJB सेशन बीन को तैनात किया जाना है।

  • उपरोक्त इंटरफ़ेस को लागू करने के लिए एक स्टेटलेस सेशन बीन बनाएँ।

  • @ स्टेटलेस एनोटेशन का उपयोग करके इसे स्टैटिनलेस बीन का संकेत दें। ईजेबी कंटेनर तैनाती के दौरान इस एनोटेशन को पढ़ने के लिए आवश्यक प्रासंगिक कॉन्फ़िगरेशन या इंटरफेस को स्वचालित रूप से बनाता है।

रिमोट इंटरफ़ेस

import javax.ejb.Remote;
 
@Remote
public interface LibrarySessionBeanRemote {
   //add business method declarations
}

स्टेटलेस ईजेबी

@Stateless
public class LibrarySessionBean implements LibrarySessionBeanRemote {
   //implement business method 
}

उदाहरण अनुप्रयोग

आइए हम स्टेटलेस ईजेबी का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.stateless के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप EJB में बनाई गई परियोजना का उपयोग भी कर सकते हैं - स्टेटस EJB अवधारणाओं को समझने के लिए इस अध्याय के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं LibrarySessionBean.java और LibrarySessionBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (EJB मॉड्यूल)

LibrarySessionBeanRemote.java

package com.tutorialspoint.stateless;
 
import java.util.List;
import javax.ejb.Remote;
 
@Remote
public interface LibrarySessionBeanRemote {
   void addBook(String bookName);
   List getBooks();
}

LibrarySessionBean.java

package com.tutorialspoint.stateless;
 
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;
 
@Stateless
public class LibrarySessionBean implements LibrarySessionBeanRemote {
    
   List<String> bookShelf;    
 
   public LibrarySessionBean() {
      bookShelf = new ArrayList<String>();
   }
 
   public void addBook(String bookName) {
      bookShelf.add(bookName);
   }    
 
   public List<String> getBooks() {
      return bookShelf;
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibrarySessionBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateless.LibrarySessionBeanRemote

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

...
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
   LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBeanRemote ejbName: LibrarySessionBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
 
   LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
   LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

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.testStatelessEjb();
   }
   
   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 testStatelessEjb() {
 
      try {
         int choice = 1; 
 
         LibrarySessionBeanRemote libraryBean =
         LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/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++;
         }       
         LibrarySessionBeanRemote libraryBean1 = 
            (LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/remote");
         List<String> booksList1 = libraryBean1.getBooks();
         System.out.println(
            "***Using second lookup to get library stateless object***");
         System.out.println(
            "Book(s) entered so far: " + booksList1.size());
         for (int i = 0; i < booksList1.size(); ++i) {
            System.out.println((i+1)+". " + booksList1.get(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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatelessEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibrarySessionBean / रिमोट" दूरस्थ व्यापार ऑब्जेक्ट (स्टेटलेस ejb) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद दर्ज करने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन अपने उदाहरण चर में पुस्तक को संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

  • फिर एक और jindi लुकअप नाम के साथ किया जाता है - "LibrarySessionBean / रिमोट" दूरस्थ व्यापार वस्तु (स्टेटलेस EJB) को फिर से प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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
***Using second lookup to get library stateless object***
Book(s) entered so far: 0
BUILD SUCCESSFUL (total time: 13 seconds)

क्लाइंट को फिर से ईजेबी एक्सेस करने के लिए चलाएँ

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 0
***Using second lookup to get library stateless object***
Book(s) entered so far: 1
1. Learn Java
BUILD SUCCESSFUL (total time: 12 seconds)
  • ऊपर दिखाए गए आउटपुट भिन्न-भिन्न हो सकते हैं, जो इस बात पर निर्भर करता है कि JJoss कितने स्टेटलेस EJB ऑब्जेक्ट को बनाए रख रहा है।

  • मामले में, एक एकल स्टेटलेस ईजेबी ऑब्जेक्ट बनाए रखा जाता है, आप प्रत्येक खोज के बाद पुस्तकों की एक ही सूची देख सकते हैं।

  • EJB कंटेनर हर लुकअप के लिए एक ही स्टेटलेस EJB ऑब्जेक्ट लौटा सकता है।

  • स्टेटलेस ईजेबी बीन तब तक अस्थिर चर का मान रख रहा है जब तक कि सर्वर पुनः आरंभ नहीं होता है।

एक स्टेटफुल सेशन बीन एंटरप्राइज सेम का एक प्रकार है, जो क्लाइंट के साथ संवादी स्थिति को संरक्षित करता है। अपने नाम के अनुसार एक स्टेटफुल सेशन बीन अपने क्लाइंट वेरिएबल में संबंधित क्लाइंट स्टेट रखता है। EJB कंटेनर क्लाइंट के प्रत्येक अनुरोध को प्रोसेस करने के लिए एक अलग स्टेटफुल सेशन बीन बनाता है। जैसे ही अनुरोध की गुंजाइश खत्म हो जाती है, वैधानिक सत्र सेम नष्ट हो जाता है।

स्टेटफुल ईजेबी बनाने के लिए कदम

एक स्टेटस EJB बनाने के लिए आवश्यक कदम निम्नलिखित हैं -

  • व्यावसायिक विधियों को उजागर करने वाला एक दूरस्थ / स्थानीय इंटरफ़ेस बनाएं।

  • इस इंटरफ़ेस का उपयोग EJB क्लाइंट एप्लिकेशन द्वारा किया जाएगा।

  • यदि EJB क्लाइंट उसी वातावरण में है जहाँ EJB सत्र बीन को तैनात करने की आवश्यकता है तो @Local एनोटेशन का उपयोग करें।

  • यदि EJB क्लाइंट अलग-अलग वातावरण में है, तो @Remote एनोटेशन का उपयोग करें जहाँ EJB सत्र बीन को तैनात करने की आवश्यकता है।

  • उपरोक्त इंटरफ़ेस को लागू करने के लिए एक राज्य सत्र बीन बनाएँ।

  • इसे स्टेटीन बीन का संकेत देने के लिए @Stateful एनोटेशन का उपयोग करें। ईजेबी कंटेनर तैनाती के दौरान इस एनोटेशन को पढ़ने के लिए आवश्यक प्रासंगिक कॉन्फ़िगरेशन या इंटरफेस को स्वचालित रूप से बनाता है।

रिमोट इंटरफ़ेस

import javax.ejb.Remote;
 
@Remote
public interface LibraryStatefulSessionBeanRemote {
   //add business method declarations
}

स्टेटफुल ईजेबी

@Stateful
public class LibraryStatefulSessionBean implements LibraryStatefulSessionBeanRemote {
   //implement business method 
}

उदाहरण अनुप्रयोग

हमें स्टेटफुल ईजेबी का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.stateful के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप EJB में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए स्टेटस EJB अवधारणाओं को समझने के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं LibraryStatefulSessionBean.java और LibraryStatefulSessionBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (EJB मॉड्यूल)

LibraryStatefulSessionBeanRemote.java

package com.tutorialspoint.stateful;
 
import java.util.List;
import javax.ejb.Remote;
 
@Remote
public interface LibraryStatefulSessionBeanRemote {
   void addBook(String bookName);
   List getBooks();
}

LibraryStatefulSessionBean.java

package com.tutorialspoint.stateful;
 
import java.util.ArrayList;
import java.util.List;
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;
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryStatefulSessionBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateful.LibraryStatefulSessionBeanRemote

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

...
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   LibraryStatefulSessionBean/remote - EJB3.x Default Remote Business Interface
   LibraryStatefulSessionBean/remote-com.tutorialspoint.stateful.LibraryStatefulSessionBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibraryStatefulSessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateful.LibraryStatefulSessionBeanRemote ejbName: LibraryStatefulSessionBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
 
   LibraryStatefulSessionBean/remote - EJB3.x Default Remote Business Interface
   LibraryStatefulSessionBean/remote-com.tutorialspoint.stateful.LibraryStatefulSessionBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • प्रारंभिक कॉन्टेक्स्ट ऑब्जेक्ट का उपयोग स्टेटफुल सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.LibraryStatefulSessionBeanRemote;
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.testStatelessEjb();
   }
   
   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 testStatelessEjb() {
 
      try {
         int choice = 1; 
 
         LibraryStatefulSessionBeanRemote libraryBean =
         LibraryStatefulSessionBeanRemote)ctx.lookup("LibraryStatefulSessionBean/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++;
         }       
         LibraryStatefulSessionBeanRemote libraryBean1 = 
            (LibraryStatefulSessionBeanRemote)ctx.lookup("LibraryStatefulSessionBean/remote");
         List<String> booksList1 = libraryBean1.getBooks();
         System.out.println(
            "***Using second lookup to get library stateful object***");
         System.out.println(
            "Book(s) entered so far: " + booksList1.size());
         for (int i = 0; i < booksList1.size(); ++i) {
            System.out.println((i+1)+". " + booksList1.get(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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryStatefulSessionBean / रिमोट" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल ejb) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम बुक नाम पूछता है और स्टेटफुल सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन अपने उदाहरण चर में पुस्तक को संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटफुल सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें पुनर्प्राप्त करता है और बाहर निकलता है।

  • फिर एक और jindi लुकअप नाम के साथ किया जाता है - "LibraryStatefulSessionBean / Remote" फिर से दूरस्थ व्यापार ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें -

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
***Using second lookup to get library stateful object***
Book(s) entered so far: 0
BUILD SUCCESSFUL (total time: 13 seconds)

क्लाइंट को फिर से ईजेबी एक्सेस करने के लिए चलाएँ

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 0
***Using second lookup to get library stateful object***
Book(s) entered so far: 0
BUILD SUCCESSFUL (total time: 12 seconds)
  • ऊपर दिखाया गया आउटपुट बताता है कि प्रत्येक लुकअप के लिए, एक अलग स्टेटफुल EJB उदाहरण दिया गया है।

  • स्टेटफुल EJB ऑब्जेक्ट केवल सिंगल सेशन के लिए वैल्यू रख रहा है। दूसरे भाग के रूप में, हमें पुस्तकों का कोई मूल्य नहीं मिल रहा है।

EJB 3.0, EJB 2.0 में उपयोग की जाने वाली इकाई बीन काफी हद तक दृढ़ता तंत्र द्वारा प्रतिस्थापित किया जाता है। अब यूनिट बीन टेबल के साथ मैपिंग करने वाला एक साधारण POJO है।

निम्नलिखित एपीआई में प्रमुख कलाकार हैं -

  • Entity- डेटा-स्टोर रिकॉर्ड का प्रतिनिधित्व करने वाली एक सतत वस्तु। धारावाहिक होना अच्छा है।

  • EntityManager- डेटा जोड़ने के लिए दृढ़ता इंटरफ़ेस जैसे कि ऐड / डिलीट / अपडेट / लगातार ऑब्जेक्ट (इकाई) पर खोजें। इसका उपयोग करके प्रश्नों को निष्पादित करने में भी मदद मिलती हैQuery इंटरफेस।

  • Persistence unit (persistence.xml) - दृढ़ता इकाई दृढ़ता तंत्र के गुणों का वर्णन करती है।

  • Data Source (*ds.xml)- डेटा स्रोत कनेक्शन यूआरएल जैसे डेटा-स्टोर संबंधित गुणों का वर्णन करता है। उपयोगकर्ता-नाम, पासवर्ड आदि

EJB दृढ़ता तंत्र को प्रदर्शित करने के लिए, हमें निम्नलिखित कार्य करने होंगे -

  • Step 1 - डेटाबेस में तालिका बनाएं।

  • Step 2 - तालिका के अनुरूप इकाई वर्ग बनाएं।

  • Step 3 - डेटा स्रोत और दृढ़ता इकाई बनाएँ।

  • Step 4 - EntityManager उदाहरण के लिए एक स्टेटलेस EJB बनाएं।

  • Step 5- स्टेटलेस ईजेबी अपडेट करें। इकाई प्रबंधक के माध्यम से रिकॉर्ड जोड़ने और डेटाबेस से रिकॉर्ड प्राप्त करने के तरीके जोड़ें।

  • Step 6 - कंसोल आधारित एप्लिकेशन क्लाइंट डेटाबेस में डेटा को बनाए रखने के लिए स्टेटलेस ईजेबी को एक्सेस करेगा।

तालिका बनाएं

एक तालिका बनाएं books डिफ़ॉल्ट डेटाबेस में postgres

CREATE TABLE books (
   id     integer PRIMARY KEY,
   name   varchar(50)
);

इकाई वर्ग बनाएँ

//mark it entity using Entity annotation 
//map table name using Table annotation
@Entity
@Table(name="books")
public class Book implements Serializable{
    
   private int id;
   private String name;

   public Book() {        
   }

   //mark id as primary key with autogenerated value
   //map database column id with id field
   @Id
   @GeneratedValue(strategy= GenerationType.IDENTITY)
   @Column(name="id")
   public int getId() {
      return id;
   }
   ...
}

DataSource और Persistence Unit बनाएँ

DataSource (jboss-ds.xml)

<?xml version = "1.0" encoding = "UTF-8"?>
<datasources>
   <local-tx-datasource>
      <jndi-name>PostgresDS</jndi-name>
      <connection-url>jdbc:postgresql://localhost:5432/postgres</connection-url>
      <driver-class>org.postgresql.driver</driver-class>
      <user-name>sa</user-name>
      <password>sa</password>
      <min-pool-size>5</min-pool-size>
      <max-pool-size>20</max-pool-size>
      <idle-timeout-minutes>5</idle-timeout-minutes>
   </local-tx-datasource>
</datasources>

दृढ़ता इकाई (दृढ़ता। xml)

<persistence version = "1.0" xmlns = "http://java.sun.com/xml/ns/persistence" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">

   <persistence-unit name = "EjbComponentPU" transaction-type = "JTA">
      <jta-data-source>java:/PostgresDS</jta-data-source>
      <exclude-unlisted-classes>false</exclude-unlisted-classes>
      <properties/>
   </persistence-unit>
   
   <persistence-unit name = "EjbComponentPU2" transaction-type = "JTA">
      <provider>org.hibernate.ejb.HibernatePersistence</provider>
      <jta-data-source>java:/PostgresDS</jta-data-source>
      <exclude-unlisted-classes>false</exclude-unlisted-classes>
	  
      <properties>
         <property name="hibernate.hbm2ddl.auto" value="update"/>
      </properties>
   </persistence-unit>
   
</persistence>

EntityManager इंस्टेंस वाले स्टेटलेस EJB बनाएं

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
	
   //pass persistence unit to entityManager.
   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {        
      return entityManager.createQuery("From Books").getResultList();
   }
   ...
}

EJB मॉड्यूल के निर्माण के बाद, हमें स्टेटलेस बीन को एक्सेस करने के लिए क्लाइंट की आवश्यकता होती है, जिसे हम अगले भाग में बनाने जा रहे हैं।

उदाहरण अनुप्रयोग

आइए हम EJB हठ तंत्र का परीक्षण करने के लिए एक परीक्षण EJB एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप EJB में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए EJB दृढ़ता अवधारणाओं को समझने के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity और जिन्हें आप नीचे इसे संशोधित।

3

बनाएं LibraryPersistentBean.java और LibraryPersistentBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय और जिन्हें आप नीचे देख उन्हें संशोधित।

4

बनाएं jboss-ds.xml मेंEjbComponent > setup फ़ोल्डर और दृढ़ताxml मेंEjbComponent > src > conf फ़ोल्डर। इन फ़ोल्डरों को नेटबींस में फाइल टैब में देखा जा सकता है। इन फ़ाइलों को ऊपर दिखाए अनुसार संशोधित करें।

5

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

6

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

7

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB। इसे नीचे दिखाए अनुसार संशोधित करें।

EJBComponent (EJB मॉड्यूल)

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

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateless.LibraryPersistentBeanRemote

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=LibraryPersistentBeanRemote,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 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
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
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.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 निम्नलिखित कार्य करता है।

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryStatefulSessionBean / रिमोट" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल ejb) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद दर्ज करने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम बुक नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन EntityManager कॉल के माध्यम से डेटाबेस में पुस्तक को जारी रख रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटफुल सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें पुनर्प्राप्त करता है और बाहर निकलता है।

  • फिर एक और jindi लुकअप नाम के साथ किया जाता है - "LibraryStatelessSessionBean / Remote" फिर से दूरस्थ व्यापार ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें -

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: 15 seconds)

क्लाइंट को फिर से ईजेबी एक्सेस करने के लिए चलाएँ

EJB तक पहुँचने से पहले JBoss को पुनः आरंभ करें।

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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

ऊपर दिखाए गए आउटपुट में कहा गया है कि पुस्तकें लगातार स्टोरेज में संग्रहित हो रही हैं और डेटाबेस से पुनर्प्राप्त की जाती हैं।

एक संदेश संचालित बीन एक प्रकार का उद्यम बीन है, जिसे कतार या विषय से संदेश मिलने पर ईजेबी कंटेनर द्वारा लगाया जाता है। संदेश संचालित बीन एक स्टेटलेस बीन है और इसे एसिंक्रोनस रूप से कार्य करने के लिए उपयोग किया जाता है।

संदेश संचालित बीन के उपयोग को प्रदर्शित करने के लिए, हम EJB- दृढ़ता अध्याय का उपयोग करेंगे और हमें निम्नलिखित कार्य करने होंगे -

  • Step 1- डेटाबेस में तालिका बनाएं ( EJB-Persistence अध्याय का संदर्भ लें )।

  • Step 2- तालिका के अनुरूप इकाई वर्ग बनाएं ( EJB-Persistence Chapter का संदर्भ लें )।

  • Step 3- DataSource और Persistence Unit ( EJB-Persistence Chapter का संदर्भ लें ) बनाएँ ।

  • Step 4EntityManager उदाहरण ( EJB-Persistence अध्याय का संदर्भ लें ) वाला एक स्टेटलेस EJB बनाएं ।

  • Step 5- स्टेटलेस ईजेब अपडेट करें। रिकॉर्ड जोड़ने के लिए और यूनिट मैनेजर के माध्यम से डेटाबेस से रिकॉर्ड प्राप्त करने के तरीके ( ईजेबी-पर्सिस्टेंस चैप्टर का संदर्भ लें ) के लिए रिकॉर्ड करें ।

  • Step 6 - नाम से एक कतार बनाएं BookQueue JBoss में default आवेदन निर्देशिका।

  • Step 7 - एक कंसोल आधारित एप्लिकेशन क्लाइंट इस कतार को संदेश भेजेगा।

  • Step 8 - एक संदेश संचालित बीन बनाएँ, जो क्लाइंट डेटा को बनाए रखने के लिए स्टेटलेस बीन का उपयोग करेगा।

  • Step 9 - jboss का EJB कंटेनर उपर्युक्त संदेश संचालित बीन को कॉल करेगा और इसे वह संदेश देगा जो क्लाइंट को भेजा जाएगा।

कतार बनाएं

यदि मौजूद नहीं है तो एक फ़ाइल jbossmq-गंतव्यों-सेवा। Xml बनाएँ <JBoss Installation Folder> > server > default > deploy फ़ोल्डर।

यहाँ हम BookQueue नाम से एक कतार बना रहे हैं -

jbossmq-स्थलों-service.xml

<mbean code="org.jboss.mq.server.jmx.Queue"  
   name="jboss.mq.destination:service=Queue,name=BookQueue">  
   <depends optional-attribute-name="DestinationManager">
      jboss.mq:service=DestinationManager
   </depends>  
</mbean>

जब आप JBoss शुरू करते हैं, तो आपको jboss लॉग में एक समान प्रविष्टि दिखाई देगी।

...
10:37:06,167 INFO  [QueueService] Queue[/queue/BookQueue] started, fullSize=200000, pageSize=2000, downCacheSize=2000
...

संदेश प्रेरित बीन बनाएँ

@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) {
   }
}
  • LibraryMessageBean को संदेश संचालित बीन के रूप में चिह्नित करने के लिए @MessageDriven एनोटेशन के साथ एनोटेट किया गया है।

  • इसके गुणों को गंतव्य टाइप - कतार और गंतव्य - / कतार / बुकक्यू के रूप में परिभाषित किया गया है।

  • यह MessageListener इंटरफ़ेस को लागू करता है, जो ऑनमैसेज विधि को उजागर करता है।

  • इसमें एक संसाधन के रूप में MessgeDrivenContext है।

  • इस उद्देश्य के लिए जारी रखने के उद्देश्य से LibraryPersistentBeanRemote स्टेटलेस बीन इंजेक्ट किया जाता है।

EjbComponent प्रोजेक्ट बनाएं और इसे JBoss पर तैनात करें। EJB मॉड्यूल के निर्माण और तैनाती के बाद, हमें jboss कतार में एक संदेश भेजने के लिए क्लाइंट की आवश्यकता होती है।

उदाहरण अनुप्रयोग

हमें संदेश प्रेरित बीन का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप EJB में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए EJB दृढ़ता अवधारणाओं को समझने के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity में बनाया के रूप में EJB-हठ अध्याय।

3

EJB-Persistence चैप्टर में बनाई गई LibraryPersistentBean.java और LibraryPersistentBeanRemote बनाएँ ।

4

बनाएं jboss-ds.xml मेंEjbComponent > setup फ़ोल्डर और दृढ़ताxml मेंEjbComponent > src > conf फ़ोल्डर। इन फ़ोल्डरों को नेटबीन्स में फाइल टैब में देखा जा सकता है जैसा कि EJB-Persistence चैप्टर में बनाया गया है ।

5

एक पैकेज com.tutorialspoint.messagebean के तहत LibraryMessageBean.java बनाएं और इसे नीचे दिखाए अनुसार संशोधित करें।

6

ऊपर बताए अनुसार Jboss में BookQueue कतार बनाएँ ।

7

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

8

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

9

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB। इसे नीचे दिखाए अनुसार संशोधित करें।

EJBComponent (EJB मॉड्यूल)

LibraryMessageBean.java

package com.tutorialspoint.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 (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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () विधि में, Jndoss में उपलब्ध कतार का ट्रेसीकरण प्राप्त करने के लिए jndi लुकअप नाम के साथ किया जाता है - "/ queue / BookQueue"। फिर कतार सत्र का उपयोग करके प्रेषक बनाया जाता है।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद दर्ज करने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और प्रेषक पुस्तक का नाम कतार में भेजता है। जब JBoss कंटेनर कतार में इस संदेश को प्राप्त करता है, तो यह हमारे संदेश को बीन की ऑनमैसेज विधि से चलाता है। हमारे संदेश संचालित बीन तो राज्य के सत्र बीन addBook () विधि का उपयोग कर पुस्तक बचाता है। सत्र बीन EntityManager कॉल के माध्यम से डेटाबेस में पुस्तक को जारी रख रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो एक और jndi लुकअप नाम के साथ किया जाता है - "LibraryStatefulSessionBean / रिमोट" फिर से दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें -

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)

ऊपर दिखाए गए आउटपुट में कहा गया है कि हमारा संदेश संचालित बीन संदेश प्राप्त कर रहा है और लगातार भंडारण में पुस्तक संग्रहीत कर रहा है और पुस्तकें डेटाबेस से पुनर्प्राप्त की जाती हैं।

जावा 5.0 में एनोटेशन की शुरुआत की गई थी। एनोटेशन होने का उद्देश्य अपने स्रोत कोड के भीतर कक्षा में अतिरिक्त जानकारी या किसी क्लास का मेटा-डेटा संलग्न करना है। EJB 3.0 में, एनोटेशन का उपयोग EJB कक्षाओं में कॉन्फ़िगरेशन मेटा-डेटा का वर्णन करने के लिए किया जाता है। इस तरह, EJB 3.0 कॉन्फ़िगरेशन XML फ़ाइलों में कॉन्फ़िगरेशन डेटा का वर्णन करने की आवश्यकता को समाप्त करता है।

EJB कंटेनर उन एनोटेशनों को पढ़कर इंटरफेस, तैनाती डिस्क्रिप्टर जैसी आवश्यक कलाकृतियों को उत्पन्न करने के लिए संकलक उपकरण का उपयोग करता है। निम्नलिखित आमतौर पर उपयोग किए जाने वाले एनोटेशन की सूची है।

अनु क्रमांक नाम विवरण
1

javax.ejb.Stateless

निर्दिष्ट करता है कि दिया गया EJB वर्ग एक स्टेटलेस सेशन बीन है।

Attributes

  • name - सत्र सेम का नाम निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • mappedName - सत्र बीन का JNDI नाम निर्दिष्ट करने के लिए प्रयुक्त।

  • description - सत्र बीन का विवरण प्रदान करने के लिए उपयोग किया जाता है।

2

javax.ejb.Stateful

निर्दिष्ट करता है कि एक दिया गया EJB वर्ग एक स्टेटफुल सेशन बीन है।

Attributes

  • name - सत्र सेम का नाम निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • mappedName - सत्र बीन का JNDI नाम निर्दिष्ट करने के लिए प्रयुक्त।

  • description - सत्र बीन का विवरण प्रदान करने के लिए उपयोग किया जाता है।

3

javax.ejb.MessageDrivenBean

निर्दिष्ट करता है कि एक दिए गए EJB वर्ग एक संदेश संचालित बीन है।

Attributes

  • name - संदेश संचालित बीन का नाम निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • messageListenerInterface - संदेश संचालित बीन के लिए संदेश श्रोता इंटरफ़ेस निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • activationConfig - संदेश संचालित बीन के परिचालन वातावरण में संदेश-संचालित बीन के कॉन्फ़िगरेशन विवरण को निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • mappedName - सत्र बीन का JNDI नाम निर्दिष्ट करने के लिए प्रयुक्त।

  • description - सत्र बीन का विवरण प्रदान करने के लिए उपयोग किया जाता है।

4

javax.ejb.EJB

एक निर्भरता को अन्य EJB में EJB उदाहरण के रूप में निर्दिष्ट या इंजेक्ट करने के लिए उपयोग किया जाता है।

Attributes

  • name - नाम निर्दिष्ट करने के लिए उपयोग किया जाता है, जिसका उपयोग पर्यावरण में संदर्भित बीन का पता लगाने के लिए किया जाएगा।

  • beanInterface - संदर्भित बीन के इंटरफ़ेस प्रकार को निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • beanName - संदर्भित बीन का नाम प्रदान करने के लिए उपयोग किया जाता है।

  • mappedName - संदर्भित बीन का JNDI नाम निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • description - संदर्भित बीन का विवरण प्रदान करने के लिए उपयोग किया जाता है।

5

javax.ejb.Local

एक सत्र बीन के स्थानीय इंटरफ़ेस (एस) को निर्दिष्ट करने के लिए उपयोग किया जाता है। यह स्थानीय इंटरफ़ेस सत्र बीन (जो स्टेटलेस या स्टेटफुल हो सकता है) के व्यापारिक तरीकों को बताता है।

इस इंटरफ़ेस का उपयोग स्थानीय ग्राहकों के लिए व्यावसायिक विधियों को उजागर करने के लिए किया जाता है, जो EJB के समान तैनाती / आवेदन में चल रहे हैं।

Attributes

  • value - स्थानीय इंटरफेस की सूची को इंटरफेस की एक सरणी के रूप में निर्दिष्ट करने के लिए उपयोग किया जाता है।

6

javax.ejb.Remote

एक सत्र बीन के रिमोट इंटरफेस (एस) को निर्दिष्ट करने के लिए उपयोग किया जाता है। यह दूरस्थ इंटरफ़ेस सत्र बीन (जो स्टेटलेस या स्टेटफुल हो सकता है) के व्यापारिक तरीकों को बताता है।

इस इंटरफ़ेस का उपयोग दूरस्थ क्लाइंट्स के लिए व्यापारिक विधियों को उजागर करने के लिए किया जाता है, जो EJB के रूप में विभिन्न तैनाती / अनुप्रयोग में चल रहे हैं।

Attributes

  • value - रिमोट इंटरफेस की सूची को इंटरफेस की एक सरणी के रूप में निर्दिष्ट करने के लिए उपयोग किया जाता है।

7

javax.ejb.Activation ConfigProperty

एक संदेश संचालित बीन के लिए आवश्यक गुणों को निर्दिष्ट करने के लिए उपयोग किया जाता है। उदाहरण के लिए, अंतिम बिंदु, गंतव्य, संदेश चयनकर्ता आदि।

यह एनोटेशन javax.ejb.MessageDrivenBean एनोटेशन के सक्रियण विशेषता के पैरामीटर के रूप में पारित किया जाता है।

Attributes

  • propertyName - संपत्ति का नाम।

  • propertyValue - संपत्ति का मूल्य।

8

javax.ejb.PostActivate

EJB जीवनचक्र की कॉलबैक विधि निर्दिष्ट करने के लिए उपयोग किया जाता है। इस विधि को तब कहा जाएगा जब ईजेबी कंटेनर केवल बीन उदाहरण को सक्रिय / पुन: सक्रिय करता है।

इस इंटरफ़ेस का उपयोग स्थानीय ग्राहकों के लिए व्यापारिक विधियों को उजागर करने के लिए किया जाता है, जो EJB के समान तैनाती / आवेदन में चल रहे हैं।

कॉलबैक एक ऐसा तंत्र है जिसके द्वारा उद्यम बीन के जीवन चक्र को बाधित किया जा सकता है। EJB 3.0 विनिर्देश ने कॉलबैक निर्दिष्ट किया है जिसके लिए कॉलबैक हैंडलर विधियां बनाई गई हैं। EJB कंटेनर इन कॉलबैक को कॉल करता है। हम कॉलबैक विधियों को EJB वर्ग में या अलग वर्ग में परिभाषित कर सकते हैं। EJB 3.0 ने कॉलबैक के लिए कई एनोटेशन प्रदान किए हैं।

निम्नलिखित स्टेटलेस बीन के लिए कॉलबैक एनोटेशन की सूची है -

टिप्पणी विवरण
@PostConstruct पहली बार जब कोई बीन बनाई जाती है, तो उसे आमंत्रित किया जाता है।
@PreDestroy जब एक बीन को बीन पूल से निकाला जाता है या नष्ट कर दिया जाता है।

स्टेटीन बीन के लिए कॉलबैक एनोटेशन की सूची निम्नलिखित है -

टिप्पणी विवरण
@PostConstruct पहली बार जब कोई बीन बनाई जाती है, तो उसे आमंत्रित किया जाता है।
@PreDestroy जब एक बीन को बीन पूल से निकाला जाता है या नष्ट कर दिया जाता है।
@PostActivate जब एक बीन को इस्तेमाल करने के लिए लोड किया जाता है तो इनवोक किया जाता है।
@PrePassivate जब एक बीन को बीन पूल में वापस रखा जाता है तो इनवैलिड

संदेश संचालित बीन के लिए कॉलबैक एनोटेशन की सूची निम्नलिखित है -

टिप्पणी विवरण
@PostConstruct पहली बार जब कोई बीन बनाई जाती है, तो उसे आमंत्रित किया जाता है।
@PreDestroy जब एक बीन को बीन पूल से निकाला जाता है या नष्ट कर दिया जाता है।

इकाई बीन के लिए कॉलबैक एनोटेशन की सूची निम्नलिखित है -

टिप्पणी विवरण
@PrePersist डेटाबेस में एक इकाई बनाने पर लागू किया जाता है।
@PostPersist डेटाबेस में एक इकाई बनाए जाने के बाद आमंत्रित किया गया।
@PreRemove डेटाबेस से निकाले जाने पर मंगवाया गया।
@PostRemove डेटाबेस से किसी इकाई को हटाने के बाद आमंत्रित किया गया।
@PreUpdate डेटाबेस में किसी इकाई को अद्यतन करने से पहले आमंत्रित किया जाता है।
@PostLoad जब एक रिकॉर्ड डेटाबेस से प्राप्त किया जाता है और इकाई में लोड किया जाता है, तो इसे आमंत्रित किया जाता है।

उदाहरण अनुप्रयोग

आइए हम ईजेबी में विभिन्न कॉलबैक का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.stateless के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप EJB में बनी परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए EJB में विभिन्न कॉलबैक जोड़ने के लिए दृढ़ता अध्याय।

2

बनाएं LibrarySessionBean.java और LibrarySessionBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

EJB में बने बीन्स का प्रयोग करें - दृढ़ता अध्याय। नीचे दिखाए गए अनुसार कॉलबैक विधियाँ जोड़ें। बाकी फाइलों को अपरिवर्तित रखें।

4

पैकेज com.tutorialspoint.callback के तहत एक जावा क्लास बुकबैकबैकलिस्ट बनाएं । यह वर्ग कॉलबैक विधियों के पृथक्करण को प्रदर्शित करेगा।

5

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

6

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

7

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (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();
    
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateless.LibraryPersistentBeanRemote

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 (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatelessEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibrarySessionBean / रिमोट" दूरस्थ व्यापार ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन डेटाबेस में पुस्तक संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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)

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

आप 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
...

टाइमर सेवा एक तंत्र है जिसके द्वारा अनुसूचित अनुप्रयोग का निर्माण किया जा सकता है। उदाहरण के लिए, हर महीने की 1 तारीख को वेतन पर्ची जनरेशन। EJB 3.0 विनिर्देश ने @Timeout एनोटेशन निर्दिष्ट किया है, जो एक स्टेटलेस या संदेश संचालित बीन में EJB सेवा की प्रोग्रामिंग करने में मदद करता है। EJB कंटेनर विधि कहता है, जो @Timeout द्वारा एनोटेट किया गया है।

EJB टाइमर सेवा EJB कंटेनर द्वारा प्रदान की जाने वाली एक सेवा है, जो टाइमर समाप्त होने पर टाइमर बनाने और कॉलबैक शेड्यूल करने में मदद करती है।

टाइमर बनाने के लिए कदम

@Resource एनोटेशन का उपयोग करके सेम में इंजेक्ट सत्रकोटेक्स्ट -

@Stateless
public class TimerSessionBean {

   @Resource
   private SessionContext context;
   ...
}

TimerService पाने के लिए और टाइमर बनाने के लिए SessionContext ऑब्जेक्ट का उपयोग करें। मिलीसेकंड और संदेश में समय गुजारें।

public void createTimer(long duration) {
   context.getTimerService().createTimer(duration, "Hello World!");
}

टाइमर का उपयोग करने के लिए कदम

किसी विधि के लिए @Timeout एनोटेशन का उपयोग करें। रिटर्न प्रकार शून्य होना चाहिए और टाइपर के एक पैरामीटर को पास करना चाहिए। हम पहले निष्पादन के बाद टाइमर को रद्द कर रहे हैं अन्यथा यह फिक्स अंतराल के बाद भी चलता रहेगा।

@Timeout
public void timeOutHandler(Timer timer) {
   System.out.println("timeoutHandler : " + timer.getInfo());        
   timer.cancel();
}

उदाहरण अनुप्रयोग

आइए हम ईजेबी में टाइमर सेवा का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.timer के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय।

2

बनाएं TimerSessionBean.java और TimerSessionBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (EJB मॉड्यूल)

TimerSessionBean.java

package com.tutorialspoint.timer;

import javax.annotation.Resource;
import javax.ejb.SessionContext;
import javax.ejb.Timer;
import javax.ejb.Stateless;
import javax.ejb.Timeout;

@Stateless
public class TimerSessionBean implements TimerSessionBeanRemote {

   @Resource
   private SessionContext context;

   public void createTimer(long duration) {
      context.getTimerService().createTimer(duration, "Hello World!");
   }

   @Timeout
   public void timeOutHandler(Timer timer) {
      System.out.println("timeoutHandler : " + timer.getInfo());        
      timer.cancel();
   }
}

TimerSessionBeanRemote.java

package com.tutorialspoint.timer;

import javax.ejb.Remote;

@Remote
public interface TimerSessionBeanRemote {
   public void createTimer(long milliseconds);
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - TimerSessionBean/remote

  • हम इस लुकअप स्ट्रिंग का उपयोग दूरस्थ प्रकार की दूरस्थ व्यावसायिक वस्तु प्राप्त करने के लिए करेंगे - com.tutorialspoint.timer.TimerSessionBeanRemote

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

...
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   TimerSessionBean/remote - EJB3.x Default Remote Business Interface
   TimerSessionBean/remote-com.tutorialspoint.timer.TimerSessionBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=TimerSessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.timer.TimerSessionBeanRemote ejbName: TimerSessionBean
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.TimerSessionBeanRemote;
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.testTimerService();
   }
   
   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 testTimerService() {
      try {
         TimerSessionBeanRemote timerServiceBean = (TimerSessionBeanRemote)ctx.lookup("TimerSessionBean/remote");

         System.out.println("["+(new Date()).toString()+ "]" + "timer created.");
         timerServiceBean.createTimer(2000);            

      } catch (NamingException ex) {
         ex.printStackTrace();
      }
   }
}

EJBTester निम्नलिखित कार्य कर रहा है।

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestTimerService () विधि में, jndi लुकअप नाम के साथ किया जाता है - "TimerSessionBean / रिमोट" दूरस्थ व्यापार वस्तु (टाइमर स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर createTimer को शेड्यूल टाइम के रूप में 2000 मिलीसेकंड पास करने के लिए आमंत्रित किया जाता है।

  • EJB कंटेनर 2 सेकंड के बाद टाइमआउटहैंडलर विधि को कॉल करता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
[Wed Jun 19 11:35:47 IST 2013]timer created.
BUILD SUCCESSFUL (total time: 0 seconds)

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

आप JBoss लॉग में निम्नलिखित कॉलबैक प्रविष्टियाँ पा सकते हैं

...
11:35:49,555 INFO  [STDOUT] timeoutHandler : Hello World!
...

EJB 3.0 विनिर्देश एनोटेशन प्रदान करता है, जो निर्भरता को इंजेक्ट करने के लिए फ़ील्ड या सेटर विधियों पर लागू किया जा सकता है। EJB कंटेनर निर्भरता का पता लगाने के लिए वैश्विक JNDI रजिस्ट्री का उपयोग करता है। निर्भरता इंजेक्शन के लिए EJB 3.0 में एनोटेशन का उपयोग किया जाता है।

  • @EJB - अन्य EJB संदर्भ इंजेक्षन करने के लिए इस्तेमाल किया।

  • @Resource - डेट्रॉक्टसोर्स या सिंगलटन सेवाओं का उपयोग करने के लिए उपयोग किया जाता है जैसे सेशनकोटेक्स्ट, टाइमरसर्विस आदि।

@EJB का उपयोग करने के लिए कदम

@ ईजेबी का उपयोग खेतों या तरीकों पर निम्नलिखित तरीके से किया जा सकता है -

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

@Resource का उपयोग करने के लिए चरण

@Resource आमतौर पर ईजेबी कंटेनर प्रदान करने के लिए प्रयोग किया जाता है, बशर्ते सिंगलटन।

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

उदाहरण अनुप्रयोग

आइए हम ईजेबी में डिपेंडेंसी इंजेक्शन सेवा का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.timer के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय।

2

EJB में निर्मित बीन्स का उपयोग करें - संदेश प्रेरित बीन अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (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 (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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () पद्धति में, Jboss में उपलब्ध कतार के संदर्भ को प्राप्त करने के लिए jndi लुकअप नाम के साथ किया जाता है - "/ queue / BookQueue"। फिर कतार सत्र का उपयोग करके प्रेषक बनाया जाता है।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और प्रेषक पुस्तक का नाम कतार में भेजता है। जब JBoss कंटेनर कतार में इस संदेश को प्राप्त करता है, तो यह हमारे संदेश को बीन की ऑनमैसेज विधि से चलाता है। हमारे संदेश संचालित बीन तो राज्य के सत्र बीन addBook () विधि का उपयोग कर पुस्तक बचाता है। सत्र बीन EntityManager कॉल के माध्यम से डेटाबेस में पुस्तक को जारी रख रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो एक और jndi लुकअप नाम के साथ किया जाता है - "LibraryStatefulSessionBean / रिमोट" फिर से दूरस्थ व्यापार ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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)

ऊपर दिखाए गए आउटपुट में कहा गया है कि हमारा संदेश संचालित बीन संदेश प्राप्त कर रहा है और लगातार भंडारण में पुस्तक संग्रहीत करता है और पुस्तकों को डेटाबेस से पुनर्प्राप्त किया जाता है।

हमारा संदेश संचालित बीन LibraryEersistentBean का उपयोग करके इसे @EJB एनोटेशन का उपयोग करके इंजेक्ट किया गया है और अपवाद के मामले में, MessageDrivenContext, ऑब्जेक्ट का उपयोग लेन-देन को रोलबैक करने के लिए किया जाता है।

EJB 3.0 @AroundInvoke एनोटेशन के साथ एनोटेट किए गए तरीकों का उपयोग करके व्यापारिक विधियों को कॉल करने के लिए विनिर्देश प्रदान करता है। एक इंटरसेप्टर विधि को ejbContainer द्वारा बुलाया जाता है, इससे पहले कि बिजनेस मेथड इंटरसेप्ट हो। इंटरसेप्टर विधि का उदाहरण हस्ताक्षर निम्नलिखित है

@AroundInvoke
public Object methodInterceptor(InvocationContext ctx) throws Exception {
   System.out.println("*** Intercepting call to LibraryBean method: " 
   + ctx.getMethod().getName());
   return ctx.proceed();
}

इंटरसेप्टर विधियों को तीन स्तरों पर लागू या बाध्य किया जा सकता है।

  • Default - डिफॉल्ट इंटरसेप्टर को तैनाती के भीतर प्रत्येक बीन के लिए आमंत्रित किया जाता है। डीफॉल्ट इंटरसेप्टर को केवल xml (ejb-jar.xml) के माध्यम से लागू किया जा सकता है।

  • Class- बीन के हर तरीके के लिए क्लास लेवल इंटरसेप्टर लगाया जाता है। क्लास स्तर के इंटरसेप्टर को xml (ejb-jar.xml) के माध्यम से एनोटेशन द्वारा लागू किया जा सकता है।

  • Method- बीन की एक विशेष विधि के लिए विधि स्तर इंटरसेप्टर का उपयोग किया जाता है। विधि स्तर इंटरसेप्टर को xml (ejb-jar.xml) के माध्यम से एनोटेशन द्वारा लागू किया जा सकता है।

हम यहां कक्षा स्तर के इंटरसेप्टर पर चर्चा कर रहे हैं।

इंटरसेप्टर क्लास

package com.tutorialspoint.interceptor;

import javax.interceptor.AroundInvoke;
import javax.interceptor.InvocationContext;

public class BusinessInterceptor {
   @AroundInvoke
   public Object methodInterceptor(InvocationContext ctx) throws Exception {
      System.out.println("*** Intercepting call to LibraryBean method: " 
      + ctx.getMethod().getName());
      return ctx.proceed();
   }
}

रिमोट इंटरफ़ेस

import javax.ejb.Remote;

@Remote
public interface LibraryBeanRemote {
   //add business method declarations
}

इंटरप्टेड स्टेटलेस ईजेबी

@Interceptors ({BusinessInterceptor.class})
@Stateless
public class LibraryBean implements LibraryBeanRemote {
   //implement business method 
}

उदाहरण अनुप्रयोग

आइए हम इंटरसेप्टेड स्टेटलेस ईजेबी का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.interceptor के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप ईजेबी में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इंटरसेप्टेड ईजेबी अवधारणाओं को समझने के लिए इस अध्याय के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं LibraryBean.java और LibraryBeanRemote पैकेज के अंतर्गत com.tutorialspoint.interceptor के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब ejb क्लाइंट बनाएं, जिस प्रकार से EJB में बताया गया है उसी तरह से एक कंसोल बेस्ड एप्लिकेशन - टॉपिक के तहत एप्लिकेशन चैप्टर बनाएंCreate Client to access EJB

EJBComponent (EJB मॉड्यूल)

LibraryBeanRemote.java

package com.tutorialspoint.interceptor;

import java.util.List;
import javax.ejb.Remote;

@Remote
public interface LibraryBeanRemote {
   void addBook(String bookName);
   List getBooks();
}

LibraryBean.java

package com.tutorialspoint.interceptor;

import java.util.ArrayList;
import java.util.List;

import javax.ejb.Stateless;
import javax.interceptor.Interceptors;

@Interceptors ({BusinessInterceptor.class})
@Stateless
public class LibraryBean implements LibraryBeanRemote {
    
   List<String> bookShelf;    

   public LibraryBean() {
      bookShelf = new ArrayList<String>();
   }

   public void addBook(String bookName) {
      bookShelf.add(bookName);
   }    

   public List<String> getBooks() {
      return bookShelf;
   }   
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryBean/remote

  • हम इस लुकअप स्ट्रिंग का उपयोग दूरस्थ प्रकार की दूरस्थ व्यावसायिक वस्तु प्राप्त करने के लिए करेंगे - com.tutorialspoint.interceptor.LibraryBeanRemote

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

...
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   LibraryBean/remote - EJB3.x Default Remote Business Interface
   LibraryBean/remote-com.tutorialspoint.interceptor.LibraryBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibraryBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.interceptor.LibraryBeanRemote ejbName: LibraryBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibraryBean/remote - EJB3.x Default Remote Business Interface
   LibraryBean/remote-com.tutorialspoint.interceptor.LibraryBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.LibraryBeanRemote;

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

      try {
         int choice = 1; 

         LibraryBeanRemote libraryBean =
         LibraryBeanRemote)ctx.lookup("LibraryBean/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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestInterceptedEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryBean / रिमोट" दूरस्थ व्यापार ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन अपने उदाहरण चर में पुस्तक को संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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)

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

JBoss अनुप्रयोग सर्वर लॉग आउटपुट में निम्न आउटपुट की जाँच करें।

....
09:55:40,741 INFO  [STDOUT] *** Intercepting call to LibraryBean method: addBook
09:55:43,661 INFO  [STDOUT] *** Intercepting call to LibraryBean method: getBooks

EJB 3.0 एक इकाई बीन में JAVA POJO (प्लेन ओल्ड जावा ऑब्जेक्ट) एम्बेड करने का विकल्प प्रदान करता है और एम्बेडेड POJO वर्ग के तरीकों के साथ कॉलम के नाम को मैप करने की अनुमति देता है। एक जावा POJO को एम्बेड किया जाना चाहिए @Embeddable के रूप में एनोटेट किया जाना चाहिए।

@Embeddable
public class Publisher implements Serializable{
   private String name;
   private String address;
   ...
}

@Embedded एनोटेशन का उपयोग करके उपरोक्त वर्ग को एम्बेड किया जा सकता है।

@Entity
public class Book implements Serializable{
   private int id;
   private String name;
   private Publisher publisher;
   ...
   @Embedded
   @AttributeOverrides({
      @AttributeOverride(name = "name", 
                      column = @Column(name = "PUBLISHER")),
      @AttributeOverride(name = "address", 
                      column = @Column(name = "PUBLISHER_ADDRESS"))
   })
   public Publisher getPublisher() {
      return publisher;
   }
   ...
}

उदाहरण अनुप्रयोग

हमें EJB 3.0 में एम्बेडेड ऑब्जेक्ट्स का परीक्षण करने के लिए एक परीक्षण EJB एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। EJB में बनाई गई परियोजना का उपयोग करें - इस अध्याय के रूप में दृढ़ता अध्याय EJB अवधारणाओं में एम्बेडेड वस्तुओं को समझने के लिए।

2

बनाएं Publisher.java पैकेज के अंतर्गत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity । संदर्भ के रूप में ईजेबी - दृढ़ता अध्याय का उपयोग करें । बाकी फाइलों को अपरिवर्तित रखें।

4

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

5

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

6

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

पुस्तक तालिका बनाएं / बदलें

CREATE TABLE book (
   id     integer PRIMARY KEY,
   name   varchar(50)
);
Alter table book add publisher varchar(100);
Alter table book add publisher_address varchar(200);

EJBComponent (EJB मॉड्यूल)

Publisher.java

package com.tutorialspoint.entity;

import java.io.Serializable;
import javax.persistence.Embeddable;

@Embeddable
public class Publisher implements Serializable{
    
   private String name;
   private String address;

   public Publisher() {}

   public Publisher(String name, String address) {
      this.name = name;
      this.address = address;
   }

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }

   public String getAddress() {
      return address;
   }

   public void setAddress(String address) {
      this.address = address;
   }

   public String toString() {
      return name + "," + address;
   }    
}

Book.java

package com.tutorialspoint.entity;

import com.tutorialspoint.callback.BookCallbackListener;
import java.io.Serializable;

import javax.persistence.AttributeOverride;
import javax.persistence.AttributeOverrides;
import javax.persistence.Column;
import javax.persistence.Embedded;
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="book")
public class Book implements Serializable{

   private int id;
   private String name;
   private Publisher publisher;

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


   @Embedded
   @AttributeOverrides({
      @AttributeOverride(name = "name", 
         column = @Column(name = "PUBLISHER")),
      @AttributeOverride(name = "address", 
         column = @Column(name = "PUBLISHER_ADDRESS"))
   })
   public Publisher getPublisher() {
      return publisher;
   }

   public void setPublisher(Publisher publisher) {
      this.publisher = publisher;
   }    
}

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.interceptor.LibraryPersistentBeanRemote

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.interceptor.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.interceptor.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
   LibraryPersistentBean/remote-com.tutorialspoint.interceptor.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.LibraryBeanRemote;

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

      try {
         int choice = 1; 

         LibraryPersistentBeanRemote libraryBean = 
        (LibraryPersistentBeanRemote)
         ctx.lookup("LibraryPersistentBean/remote");

         while (choice != 2) {
            String bookName;
            String publisherName;
            String publisherAddress;
            showGUI();
            String strChoice = brConsoleReader.readLine();
            choice = Integer.parseInt(strChoice);
            if (choice == 1) {
               System.out.print("Enter book name: ");
               bookName = brConsoleReader.readLine();
               System.out.print("Enter publisher name: ");
               publisherName = brConsoleReader.readLine();
               System.out.print("Enter publisher address: ");
               publisherAddress = brConsoleReader.readLine();
               Book book = new Book();
               book.setName(bookName);
               book.setPublisher
              (new Publisher(publisherName,publisherAddress));

               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());
            System.out.println("Publication: "+book.getPublisher());
            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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestInterceptedEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryPersistenceBean / Remote" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन डेटाबेस में पुस्तक संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: learn html5
Enter publisher name: SAMS
Enter publisher address: DELHI
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 1
1. learn html5
Publication: SAMS,DELHI
BUILD SUCCESSFUL (total time: 21 seconds)

EJB 3.0 ब्लॉब और क्लोब प्रकार @Lob एनोटेशन का उपयोग करने के लिए समर्थन प्रदान करता है। @Lob एनोटेशन का उपयोग करके जावा प्रकारों को मैप किया जा सकता है।

  • java.sql.Blob
  • java.sql.Clob
  • byte[]
  • String
  • सीरियल करने योग्य वस्तु
@Entity
@Table(name="books")
@EntityListeners(BookCallbackListener.class)
public class Book implements Serializable{
   ...
   private byte[] image;    

   @Lob @Basic(fetch= FetchType.EAGER)
   public byte[] getImage() {
      return image;
   }
   ...
}

उदाहरण अनुप्रयोग

आइए हम EJB 3.0 में बूँद / क्लोब समर्थन का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। कृपया EJB में बनाई गई परियोजना का उपयोग करें - इस अध्याय के रूप में दृढ़ता अध्याय को ebb अवधारणाओं में clob / बूँद वस्तुओं को समझने के लिए।

2

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity । संदर्भ के रूप में ईजेबी - दृढ़ता अध्याय का उपयोग करें । बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

5

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

पुस्तक तालिका बनाएं / बदलें

CREATE TABLE book (
   id     integer PRIMARY KEY,
   name   varchar(50)
);
Alter table book add image bytea;
Alter table book add xml text;

EJBComponent (EJB मॉड्यूल)

Book.java

package com.tutorialspoint.entity;

import com.tutorialspoint.callback.BookCallbackListener;
import java.io.Serializable;
import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EntityListeners;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Lob;
import javax.persistence.Table;

@Entity
@Table(name="book")
public class Book implements Serializable{
    
   private int id;
   private String name;    
   private byte[] image;   
   private String xml;

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

   @Lob @Basic(fetch= FetchType.EAGER)
   public byte[] getImage() {
      return image;
   }

   public void setImage(byte[] image) {
      this.image = image;
   }

   @Lob @Basic(fetch= FetchType.EAGER)
   public String getXml() {
      return xml;
   }

   public void setXml(String xml) {
      this.xml = xml;
   }
}

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम इस लुकअप स्ट्रिंग का उपयोग दूरस्थ प्रकार की दूरस्थ व्यावसायिक वस्तु प्राप्त करने के लिए करेंगे - com.tutorialspoint.interceptor.LibraryPersistentBeanRemote

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.interceptor.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.interceptor.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
   LibraryPersistentBean/remote-com.tutorialspoint.interceptor.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.LibraryBeanRemote;
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.testBlobClob();
   }
   
   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 testBlobClob() {

      try {
         int choice = 1; 

         LibraryPersistentBeanRemote libraryBean = 
        (LibraryPersistentBeanRemote)
         ctx.lookup("LibraryPersistentBean/remote");

         while (choice != 2) {
            String bookName;
            String publisherName;
            String publisherAddress;
            showGUI();
            String strChoice = brConsoleReader.readLine();
            choice = Integer.parseInt(strChoice);
            if (choice == 1) {
               System.out.print("Enter book name: ");
               bookName = brConsoleReader.readLine();
               String xml = "<book><name>"+bookName+"</name></book>";
               Book book = new Book();
               book.setName(bookName);                                        
               byte[] imageBytes = {0x32, 0x32,0x32, 0x32,0x32,
               0x32,0x32, 0x32,
               0x32, 0x32,0x32, 0x32,0x32, 0x32,0x32, 0x32,
               0x32, 0x32,0x32, 0x32,0x32, 0x32,0x32, 0x32
               };
               book.setImage(imageBytes);
               book.setXml(xml);

               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());
            byte[] imageByts = book.getImage();
            if(imageByts != null) {
               System.out.print("image bytes: [");
               for(int j = 0; j < imageByts.length ; j++) {
                  System.out.print("0x" 
                  + String.format("%x", imageByts[j]) +" ");
               }            
               System.out.println("]");
            }        
            System.out.println(book.getXml());
            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 निम्नलिखित कार्य करता है।

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestInterceptedEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryPersistenceBean / Remote" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन डेटाबेस में पुस्तक संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: learn testing
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 1
1. learn testing
image bytes: [
   0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 0x32 ]
<book><name>learn testing</name></book>
BUILD SUCCESSFUL (total time: 20 seconds)

लेन-देन कार्य आइटमों की एकल इकाई है, जो ACID गुणों का अनुसरण करती है। ACID का अर्थ है परमाणु, सुसंगत, पृथक और टिकाऊ।

  • Atomic- यदि कोई भी कार्य मद विफल हो जाता है, तो पूरी इकाई को विफल माना जाएगा। सफलता का मतलब है, सभी आइटम सफलतापूर्वक निष्पादित होते हैं।

  • Consistent - एक लेन-देन को सिस्टम को सुसंगत स्थिति में रखना चाहिए।

  • Isolated - प्रत्येक लेनदेन किसी अन्य लेनदेन से स्वतंत्र निष्पादित करता है।

  • Durable - लेन-देन को सिस्टम की विफलता से बचाना चाहिए यदि इसे निष्पादित या प्रतिबद्ध किया गया है।

EJB कंटेनर / सर्वर लेन-देन सर्वर हैं और लेनदेन संदर्भ प्रसार और वितरित लेनदेन को संभालते हैं। लेन-देन कंटेनर द्वारा या बीन के कोड में कस्टम कोड हैंडलिंग द्वारा प्रबंधित किया जा सकता है।

  • Container Managed Transactions - इस प्रकार में, कंटेनर लेनदेन राज्यों का प्रबंधन करता है।

  • Bean Managed Transactions - इस प्रकार में, डेवलपर लेनदेन राज्यों के जीवन चक्र का प्रबंधन करता है।

कंटेनर प्रबंधित लेनदेन

EJB 3.0 ने लेन-देन की निम्नलिखित विशेषताएं निर्दिष्ट की हैं, जिन्हें EJB कंटेनर कार्यान्वित करते हैं -

  • REQUIRED - इंगित करता है कि लेन-देन के भीतर व्यावसायिक पद्धति को निष्पादित किया जाना है, अन्यथा उस पद्धति के लिए एक नया लेनदेन शुरू किया जाएगा।

  • REQUIRES_NEW - इंगित करता है कि व्यापार पद्धति के लिए एक नया लेनदेन शुरू किया जाना है।

  • SUPPORTS - इंगित करता है कि व्यापार विधि लेनदेन के हिस्से के रूप में निष्पादित होगी।

  • NOT_SUPPORTED - इंगित करता है कि लेन-देन के हिस्से के रूप में व्यावसायिक पद्धति को निष्पादित नहीं किया जाना चाहिए।

  • MANDATORY - इंगित करता है कि व्यापार विधि लेनदेन के हिस्से के रूप में निष्पादित होगी, अन्यथा अपवाद फेंक दिया जाएगा।

  • NEVER - इंगित करता है कि यदि व्यापार विधि लेनदेन के हिस्से के रूप में निष्पादित होती है, तो एक अपवाद फेंक दिया जाएगा।

उदाहरण

package com.tutorialspoint.txn.required;
 
import javax.ejb.*
 
@Stateless
@TransactionManagement(TransactionManagementType.CONTAINER)
public class UserDetailBean implements UserDetailRemote {
	
   private UserDetail;

   @TransactionAttribute(TransactionAttributeType.REQUIRED)
   public void createUserDetail() {
      //create user details object
   }
}

createUserDetail () व्यवसाय विधि आवश्यक एनोटेशन का उपयोग करके आवश्यक बनाया गया है।

package com.tutorialspoint.txn.required;
 
import javax.ejb.*
 
@Stateless
public class UserSessionBean implements UserRemote {
	
   private User;

   @EJB
   private UserDetailRemote userDetail;

   public void createUser() {
      //create user 
      //...
      //create user details
      userDetail.createUserDetail();
   }
}

createUser () व्यवसाय विधि createUserDetail () का उपयोग कर रही है। यदि CreateUser () कॉल और उपयोगकर्ता ऑब्जेक्ट के दौरान अपवाद नहीं हुआ है तो UserDetail ऑब्जेक्ट भी नहीं बनाया जाएगा।

बीन प्रबंधित लेनदेन

बीन प्रबंधित लेनदेन में, लेनदेन को आवेदन स्तर पर अपवादों को संभालने के द्वारा प्रबंधित किया जा सकता है।

निम्नलिखित महत्वपूर्ण बिंदुओं पर विचार किया जा रहा है -

  • Start - व्यापार विधि में लेनदेन कब शुरू करें।

  • Sucess - जब लेनदेन करना हो तो सफलता के परिदृश्य को पहचानें।

  • Failed - विफलता परिदृश्य को पहचानें जब एक लेन-देन रोलबैक होना है।

उदाहरण

package com.tutorialspoint.txn.bmt;
 
import javax.annotation.Resource;
import javax.ejb.Stateless;
import javax.ejb.TransactionManagement;
import javax.ejb.TransactionManagementType;
import javax.transaction.UserTransaction;
 
@Stateless
@TransactionManagement(value=TransactionManagementType.BEAN)
public class AccountBean implements AccountBeanLocal {
 
   @Resource
   private UserTransaction userTransaction;

   public void transferFund(Account fromAccount, double fund , 
      Account toAccount) throws Exception{

      try{
         userTransaction.begin();

         confirmAccountDetail(fromAccount);
         withdrawAmount(fromAccount,fund);

         confirmAccountDetail(toAccount);
         depositAmount(toAccount,fund);

         userTransaction.commit();
      }catch (InvalidAccountException exception) {
         userTransaction.rollback();
      }catch (InsufficientFundException exception) {
         userTransaction.rollback();
      }catch (PaymentException exception) {
         userTransaction.rollback();
      }
   }

   private void confirmAccountDetail(Account account) 
      throws InvalidAccountException {
   }

   private void withdrawAmount() throws InsufficientFundException {
   }

   private void depositAmount() throws PaymentException{
   }
}

इस उदाहरण में, हमने इसका उपयोग किया UserTransaction लेन-देन की शुरुआत का उपयोग करने के लिए इंटरफ़ेस userTransaction.begin()विधि कॉल। हम लेनदेन के पूरा होने का उपयोग करके चिह्नित करते हैंuserTransaction.commit() विधि और यदि कोई अपवाद लेन-देन के दौरान हुआ, तो हम पूर्ण लेन-देन का उपयोग करके रोलबैक करते हैं userTransaction.rollback() विधि कॉल।

सुरक्षा किसी भी उद्यम स्तर के आवेदन की एक प्रमुख चिंता है। इसमें उपयोगकर्ता (नों) की पहचान या एप्लिकेशन तक पहुंचने वाली प्रणाली शामिल है। पहचान के आधार पर, यह एप्लिकेशन के भीतर संसाधनों तक पहुंच की अनुमति देता है या इनकार करता है। एक EJB कंटेनर मानक सुरक्षा चिंताओं का प्रबंधन करता है या इसे किसी भी विशिष्ट सुरक्षा चिंताओं को संभालने के लिए अनुकूलित किया जा सकता है।

सुरक्षा की महत्वपूर्ण शर्तें

  • Authentication - यह वह प्रक्रिया है जो सुनिश्चित करती है कि उपयोगकर्ता सिस्टम या एप्लिकेशन तक पहुंच प्रमाणित कर रहा है।

  • Authorization - यह सुनिश्चित करने की प्रक्रिया है कि प्रामाणिक उपयोगकर्ता के पास सिस्टम संसाधनों तक पहुंचने के लिए अधिकार का स्तर है।

  • User - उपयोगकर्ता क्लाइंट या सिस्टम का प्रतिनिधित्व करता है, जो एप्लिकेशन तक पहुंचता है।

  • User Groups - उपयोगकर्ता कुछ अधिकारियों वाले समूह का हिस्सा हो सकते हैं उदाहरण के लिए व्यवस्थापक समूह।

  • User Roles - भूमिकाएं प्राधिकरण के स्तर को परिभाषित करती हैं, एक उपयोगकर्ता के पास सिस्टम संसाधन तक पहुंचने के लिए अनुमति या अनुमति होती है।

कंटेनर प्रबंधित सुरक्षा

EJB 3.0 ने सुरक्षा के निम्नलिखित विशेषताओं / टिप्पणियों को निर्दिष्ट किया है, जिन्हें EJB कंटेनर कार्यान्वित करते हैं।

  • DeclareRoles- इंगित करता है कि वर्ग घोषित भूमिकाओं को स्वीकार करेगा। एनोटेशन को क्लास स्तर पर लागू किया जाता है।

  • RolesAllowed- इंगित करता है कि एक विधि निर्दिष्ट भूमिका के उपयोगकर्ता द्वारा पहुँचा जा सकता है। वर्ग स्तर पर लागू किया जा सकता है जिसके परिणामस्वरूप कक्षा के सभी तरीकों को निर्दिष्ट भूमिका के उपयोगकर्ता खरीद सकते हैं।

  • PermitAll- इंगित करता है कि एक व्यापार विधि सभी के लिए सुलभ है। इसे क्लास के साथ-साथ मेथड लेवल पर भी लगाया जा सकता है।

  • DenyAll - इंगित करता है कि एक व्यावसायिक विधि कक्षा या विधि स्तर पर निर्दिष्ट किसी भी उपयोगकर्ता के लिए सुलभ नहीं है।

उदाहरण

package com.tutorialspoint.security.required;
 
import javax.ejb.*
 
@Stateless
@DeclareRoles({"student" "librarian"})
public class LibraryBean implements LibraryRemote {

   @RolesAllowed({"librarian"})
   public void delete(Book book) {
	  //delete book
   }
   
   @PermitAll
   public void viewBook(Book book) {
      //view book
   }
   
   @DenyAll
   public void deleteAll() {
      //delete all books
   } 
}

सुरक्षा कॉन्फ़िगरेशन

कॉन्फ़िगरेशन फ़ाइल में मानचित्र भूमिकाएं और उपयोगकर्ता समूह।

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sun-ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Application Server 9.0 EJB 3.0//EN" "http://www.sun.com/software/appserver/dtds/sun-ejb-jar_3_0-0.dtd">
<ejb-jar>
   <security-role-mapping>
      <role-name>student</role-name>
      <group-name>student-group</group-name>
   </security-role-mapping>
   <security-role-mapping>
      <role-name>librarian</role-name>
      <group-name>librarian-group</group-name>
   </security-role-mapping>  
   <enterprise-beans/>
</ejb-jar>

JNDI का अर्थ जावा नामकरण और निर्देशिका इंटरफ़ेस है। यह एपीआई और सेवा इंटरफेस का एक सेट है। जावा आधारित अनुप्रयोग नामकरण और निर्देशिका सेवाओं के लिए JNDI का उपयोग करते हैं। EJB के संदर्भ में, दो शर्तें हैं।

  • Binding - यह एक EJB ऑब्जेक्ट को एक नाम निर्दिष्ट करने के लिए संदर्भित करता है, जिसे बाद में उपयोग किया जा सकता है।

  • Lookup - यह ईजेबी की एक वस्तु को देखने और प्राप्त करने के लिए संदर्भित करता है।

Jboss में, सत्र बीन्स डिफ़ॉल्ट रूप से निम्नलिखित प्रारूप में JNDI में बंधे होते हैं।

  • local - ईजेबी-नाम / स्थानीय

  • remote - ईजेबी-नाम / रिमोट

यदि EJB को <application-name> .ear फ़ाइल के साथ बंडल किया जाता है, तो डिफ़ॉल्ट प्रारूप निम्नानुसार है -

  • local - आवेदन-नाम / ejb- नाम / स्थानीय

  • remote - आवेदन-नाम / ejb- नाम / रिमोट

डिफ़ॉल्ट बाइंडिंग का उदाहरण

EJB का संदर्भ लें - एप्लिकेशन अध्याय JBoss कंसोल आउटपुट बनाएं

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

...
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBean ejbName: LibrarySessionBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
   LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
...

अनुकूलित बाइंडिंग

निम्नलिखित एनोटेशन का उपयोग डिफ़ॉल्ट JNDI बाइंडिंग को अनुकूलित करने के लिए किया जा सकता है -

  • local - org.jboss.ejb3.LocalBinding

  • remote - org.jboss.ejb3.emoteBindings

लाइब्रेरी सेशनबीन अपडेट करें। जावा। EJB का संदर्भ लें - एप्लिकेशन अध्याय बनाएं

LibrarySessionBean

package com.tutorialspoint.stateless;
 
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;
 
@Stateless
@LocalBinding(jndiBinding="tutorialsPoint/librarySession")
public class LibrarySessionBean implements LibrarySessionBeanLocal {
    
    List<String> bookShelf;    
    
    public LibrarySessionBean() {
       bookShelf = new ArrayList<String>();
    }
    
    public void addBook(String bookName) {
       bookShelf.add(bookName);
    }    
 
    public List<String> getBooks() {
        return bookShelf;
    }
}

LibrarySessionBeanLocal

package com.tutorialspoint.stateless;
 
import java.util.List;
import javax.ejb.Local;
 
@Local
public interface LibrarySessionBeanLocal {
 
    void addBook(String bookName);
 
    List getBooks();
    
}

प्रोजेक्ट बनाएँ, Jboss पर एप्लिकेशन को तैनात करें, और Jboss कंसोल में निम्न आउटपुट को सत्यापित करें -

...
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBean ejbName: LibrarySessionBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   tutorialsPoint/librarySession - EJB3.x Default Local Business Interface
   tutorialsPoint/librarySession-com.tutorialspoint.stateless.LibrarySessionBeanLocal - EJB3.x Local Business Interface
...

EJB 3.0 एक-से-एक, एक-से-कई, कई-से-एक, और कई-से-कई रिश्तों की तरह डेटाबेस इकाई संबंधों / मैपिंग को परिभाषित करने का विकल्प प्रदान करता है।

निम्नलिखित प्रासंगिक एनोटेशन हैं -

  • One-to-One- वस्तुओं का एक-से-एक संबंध होता है। उदाहरण के लिए, एक यात्री एक बार में एक ही टिकट का उपयोग करके यात्रा कर सकता है।

  • One-to-Many- वस्तुओं का एक से कई संबंध होते हैं। उदाहरण के लिए, एक पिता के कई बच्चे हो सकते हैं।

  • Many-to-One- वस्तुओं के कई-से-एक संबंध होते हैं। उदाहरण के लिए, एक ही माँ वाले कई बच्चे।

  • Many-to-Many- वस्तुओं के कई-से-कई संबंध होते हैं। उदाहरण के लिए, एक किताब में कई लेखक हो सकते हैं और एक लेखक कई किताबें लिख सकता है।

हम यहां कईToMany मानचित्रण का उपयोग प्रदर्शित करेंगे। ManyToMany संबंध का प्रतिनिधित्व करने के लिए, निम्नलिखित तीन तालिकाओं की आवश्यकता है -

  • Book - बुक टेबल, किताबों का रिकॉर्ड होना।

  • Author - लेखक की तालिका, लेखक के रिकॉर्ड वाले।

  • Book_Author - बुक ऑथर टेबल, ऊपर बताई गई बुक और ऑथर टेबल का लिंकेज है।

टेबल्स बनाएं

एक तालिका बनाएं book author, book_author डिफ़ॉल्ट डेटाबेस में postgres

CREATE TABLE book (
   book_id     integer,   
   name   varchar(50)      
);

CREATE TABLE author (
   author_id   integer,
   name   varchar(50)      
);

CREATE TABLE book_author (
   book_id     integer,
   author_id   integer 
);

एंटिटी क्लासेस बनाएं

@Entity
@Table(name="author")
public class Author implements Serializable{
   private int id;
   private String name;
   ...   
}

@Entity
@Table(name="book")
public class Book implements Serializable{
   private int id;
   private String title;
   private Set<Author> authors;
   ...   
}

बुक एंटिटी में कईToMany एनोटेशन का उपयोग करें।

@Entity
public class Book implements Serializable{
   ...
   @ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE}
      , fetch = FetchType.EAGER)
   @JoinTable(table = @Table(name = "book_author"),
      joinColumns = {@JoinColumn(name = "book_id")},
      inverseJoinColumns = {@JoinColumn(name = "author_id")})
   public Set<Author> getAuthors() {
      return authors;
   }
   ...
}

उदाहरण अनुप्रयोग

आइए हम ईजेबी 3.0 में इकाई संबंधों की वस्तुओं का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। EJB में बनाई गई परियोजना का उपयोग करें - इस अध्याय के रूप में दृढ़ता अध्याय EJB अवधारणाओं में एम्बेडेड वस्तुओं को समझने के लिए।

2

बनाएं Author.java पैकेज के अंतर्गत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें।

3

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity । संदर्भ के रूप में ईजेबी - दृढ़ता अध्याय का उपयोग करें । बाकी फाइलों को अपरिवर्तित रखें।

4

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

5

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

6

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB

EJBComponent (EJB मॉड्यूल)

Author.java

package com.tutorialspoint.entity;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="author")
public class Author implements Serializable{
    
   private int id;
   private String name;

   public Author() {}

   public Author(int id, String name) {
      this.id = id;
      this.name = name;
   }
   
   @Id  
   @GeneratedValue(strategy= GenerationType.IDENTITY)
   @Column(name="author_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;
   }

   public String toString() {
      return id + "," + name;
   }    
}

Book.java

package com.tutorialspoint.entity;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;

@Entity
@Table(name="book")
public class Book implements Serializable{

   private int id;
   private String name;
   private Set<Author> authors;

   public Book() {        
   }

   @Id  
   @GeneratedValue(strategy= GenerationType.IDENTITY)
   @Column(name="book_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;
   }

   public void setAuthors(Set<Author> authors) {
      this.authors = authors;
   }    
   
   @ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE}
      , fetch = FetchType.EAGER)
   @JoinTable(table = @Table(name = "book_author"),
      joinColumns = {@JoinColumn(name = "book_id")},
      inverseJoinColumns = {@JoinColumn(name = "author_id")})
   public Set<Author> getAuthors() {
      return authors;
   }
}

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम इस लुकअप स्ट्रिंग का उपयोग दूरस्थ प्रकार की दूरस्थ व्यावसायिक वस्तु प्राप्त करने के लिए करेंगे - com.tutorialspoint.interceptor.LibraryPersistentBeanRemote

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.interceptor.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.interceptor.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
   LibraryPersistentBean/remote-com.tutorialspoint.interceptor.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateful.LibraryBeanRemote;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;

import java.util.*;

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

      try {
         int choice = 1; 

         LibraryPersistentBeanRemote libraryBean = 
         (LibraryPersistentBeanRemote)
         ctx.lookup("LibraryPersistentBean/remote");

         while (choice != 2) {
            String bookName;
            String authorName;
            
            showGUI();
            String strChoice = brConsoleReader.readLine();
            choice = Integer.parseInt(strChoice);
            if (choice == 1) {
               System.out.print("Enter book name: ");
               bookName = brConsoleReader.readLine();
               System.out.print("Enter author name: ");
               authorName = brConsoleReader.readLine();               
               Book book = new Book();
               book.setName(bookName);
               Author author = new Author();
               author.setName(authorName);
               Set<Author> authors = new HashSet<Author>();
               authors.add(author);
               book.setAuthors(authors);

               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());
            System.out.print("Author: ");
            Author[] authors = (Author[])books.getAuthors().toArray();
            for(int j=0;j<authors.length;j++) {
               System.out.println(authors[j]);
            }
            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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestInterceptedEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryPersistenceBean / Remote" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन डेटाबेस में पुस्तक संग्रहीत कर रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: learn html5
Enter Author name: Robert
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 1
1. learn html5
Author: Robert
BUILD SUCCESSFUL (total time: 21 seconds)

ईजेबी 3.0 में, उस डेटाबेस तक पहुंचने के लिए दृढ़ता तंत्र का उपयोग किया जाता है जिसमें कंटेनर डेटाबेस से संबंधित संचालन का प्रबंधन करता है। डेवलपर्स JDBC API कॉल का उपयोग करके डेटाबेस को सीधे EJB व्यावसायिक विधियों में एक्सेस कर सकते हैं।

EJB में डेटाबेस का उपयोग प्रदर्शित करने के लिए, हमें निम्नलिखित कार्य करने होंगे -

  • Step 1 - डेटाबेस में एक टेबल बनाएं।

  • Step 2 - मुझे व्यापार करने वाले एक स्टेटलेस ईजेबी बनाएं।

  • Step 3- स्टेटलेस ईजेबी अपडेट करें। इकाई प्रबंधक के माध्यम से रिकॉर्ड जोड़ने और डेटाबेस से रिकॉर्ड प्राप्त करने के तरीके जोड़ें।

  • Step 4 - कंसोल आधारित एप्लिकेशन क्लाइंट डेटाबेस में डेटा को बनाए रखने के लिए स्टेटलेस ईजेबी को एक्सेस करेगा।

तालिका बनाएं

एक तालिका बनाएं books डिफ़ॉल्ट डेटाबेस में postgres

CREATE TABLE books (
   id     integer PRIMARY KEY,
   name   varchar(50)
);

एक मॉडल वर्ग बनाएँ

public class Book implements Serializable{
    
   private int id;
   private String name;

   public Book() {        
   }
   
   public int getId() {
      return id;
   }
   ...
}

स्टेटलेस ईजेबी बनाएं

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
	
   public void addBook(Book book) {
     //persist book using jdbc calls
   }    

   public List<Book> getBooks() {        
     //get books using jdbc calls
   }
   ...
}

EJB मॉड्यूल के निर्माण के बाद, हमें स्टेटलेस बीन को एक्सेस करने के लिए क्लाइंट की आवश्यकता होती है, जिसे हम अगले भाग में बनाने जा रहे हैं।

उदाहरण अनुप्रयोग

आइए हम EJB डेटाबेस एक्सेस तंत्र का परीक्षण करने के लिए एक परीक्षण EJB एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप ईजेबी में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए ईजेबी डेटा एक्सेस अवधारणाओं को समझने के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity और जिन्हें आप नीचे इसे संशोधित।

3

बनाएं LibraryPersistentBean.java और LibraryPersistentBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय और जिन्हें आप नीचे देख उन्हें संशोधित।

4

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

5

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

6

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB। इसे नीचे दिखाए अनुसार संशोधित करें।

EJBComponent (EJB मॉड्यूल)

Book.java

package com.tutorialspoint.entity;

import java.io.Serializable;

public class Book implements Serializable{
    
   private int id;
   private String name;

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

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   public void addBook(Book book) {
      Connection con = null;
      String url = "jdbc:postgresql://localhost:5432/postgres";
      String driver = "org.postgresql.driver";

      String userName = "sa";
      String password = "sa";
      List<Book> books = new ArrayList<Book>();
      try {

         Class.forName(driver).newInstance();
         con = DriverManager.getConnection(url , userName, password);

         PreparedStatement st = 
         con.prepareStatement("insert into book(name) values(?)");
         st.setString(1,book.getName());

         int result = st.executeUpdate();                

      } catch (SQLException ex) {
         ex.printStackTrace();
      } catch (InstantiationException ex) {
         ex.printStackTrace();
      } catch (IllegalAccessException ex) {
         ex.printStackTrace();
      } catch (ClassNotFoundException ex) {
         ex.printStackTrace();
      }    
   }    

   public List<Book> getBooks() {
      Connection con = null;
      String url = "jdbc:postgresql://localhost:5432/postgres";
      String driver = "org.postgresql.driver";
   
      String userName = "sa";
      String password = "sa";
      List<Book> books = new ArrayList<Book>();
      try {

         Class.forName(driver).newInstance();
         con = DriverManager.getConnection(url , userName, password);

         Statement st = con.createStatement();
         ResultSet rs = st.executeQuery("select * from book");

         Book book;
         while (rs.next()) {
            book = new Book();
            book.setId(rs.getInt(1));                 
            book.setName(rs.getString(2));
            books.add(book);
         }
      } catch (SQLException ex) {
         ex.printStackTrace();
      } catch (InstantiationException ex) {
         ex.printStackTrace();
      } catch (IllegalAccessException ex) {
         ex.printStackTrace();
      } catch (ClassNotFoundException ex) {
         ex.printStackTrace();
      }
      return books;
   }
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateless.LibraryPersistentBeanRemote

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=LibraryPersistentBeanRemote,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 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
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
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.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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryStatelessSessionBean / रिमोट" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन EntityManager कॉल के माध्यम से डेटाबेस में पुस्तक को जारी रख रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

  • फिर एक और jindi लुकअप नाम के साथ किया जाता है - "LibraryStatelessSessionBean / Remote" फिर से दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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: 15 seconds)

EJB Query Languageअंतर्निहित डेटाबेस विवरण के बारे में चिंता किए बिना कस्टम क्वेरी लिखना काफी आसान है। यह HQL, हाइबरनेट क्वेरी भाषा के समान है और अक्सर इसे EJBQL नाम से संदर्भित किया जाता है।

EJB में EJBQL प्रदर्शित करने के लिए, हम निम्नलिखित कार्य करने जा रहे हैं -

  • Step 1 - डेटाबेस में तालिका बनाएं।

  • Step 2 - मुझे व्यापार करने वाले एक स्टेटलेस ईजेबी बनाएं।

  • Step 3−Update स्टेटलेस EJB। इकाई प्रबंधक के माध्यम से रिकॉर्ड जोड़ने और डेटाबेस से रिकॉर्ड प्राप्त करने के तरीके जोड़ें।

  • Step 4 - कंसोल आधारित एप्लिकेशन क्लाइंट डेटाबेस में डेटा को बनाए रखने के लिए स्टेटलेस ईजेबी को एक्सेस करेगा।

तालिका बनाएं

एक तालिका बनाएं books डिफ़ॉल्ट डेटाबेस में postgres

CREATE TABLE books (
   id     integer PRIMARY KEY,
   name   varchar(50)
);

एक मॉडल वर्ग बनाएँ

public class Book implements Serializable{
    
   private int id;
   private String name;

   public Book() {        
   }
   
   public int getId() {
      return id;
   }
   ...
}

स्टेटलेस ईजेबी बनाएं

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
	
   public void addBook(Book book) {
     //persist book using entity manager
   }    

   public List<Book> getBooks() {        
     //get books using entity manager
   }
   ...
}

EJB मॉड्यूल के निर्माण के बाद, हमें स्टेटलेस बीन को एक्सेस करने के लिए क्लाइंट की आवश्यकता होती है, जिसे हम अगले भाग में बनाने जा रहे हैं।

उदाहरण अनुप्रयोग

आइए हम EJB डेटाबेस एक्सेस तंत्र का परीक्षण करने के लिए एक परीक्षण EJB एप्लिकेशन बनाएं।

कदम विवरण
1

एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। आप ईजेबी में बनाई गई परियोजना का उपयोग भी कर सकते हैं - इस अध्याय के लिए ईजेबी डेटा एक्सेस अवधारणाओं को समझने के लिए एप्लिकेशन अध्याय बनाएं

2

बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity और जिन्हें आप नीचे इसे संशोधित।

3

बनाएं LibraryPersistentBean.java और LibraryPersistentBeanRemote के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय और जिन्हें आप नीचे देख उन्हें संशोधित।

4

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

5

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

6

अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB। इसे नीचे दिखाए अनुसार संशोधित करें।

EJBComponent (EJB मॉड्यूल)

Book.java

package com.tutorialspoint.entity;

import java.io.Serializable;

public class Book implements Serializable{
    
   private int id;
   private String name;

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

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

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;

@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() {
      //create an ejbql expression
      String ejbQL = "From Book b where b.name like ?1";
      //create query
      Query query = entityManager.createQuery(ejbQL);
      //substitute parameter.
      query.setParameter(1, "%test%");   
      //execute the query
      return query.getResultList();
   }   
}
  • जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।

  • JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote

  • हम दूरस्थ व्यापार वस्तु प्रकार प्राप्त करने के लिए इस लुकअप स्ट्रिंग का उपयोग करेंगे - com.tutorialspoint.stateless.LibraryPersistentBeanRemote

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=LibraryPersistentBeanRemote,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 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
...

EJBTester (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
  • इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।

  • आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।

EJBTester.java

package com.tutorialspoint.test;
   
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.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 निम्नलिखित कार्य करता है -

  • Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।

  • TestStatefulEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryStatelessSessionBean / Remote" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटफुल ejb) प्राप्त करने के लिए।

  • फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।

  • यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन EntityManager कॉल के माध्यम से डेटाबेस में पुस्तक को जारी रख रहा है।

  • यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।

  • फिर एक और jindi लुकअप नाम के साथ किया जाता है - "LibraryStatelessSessionBean / Remote" फिर से दूरस्थ व्यापार ऑब्जेक्ट (स्टेटफुल EJB) प्राप्त करने के लिए और पुस्तकों की सूचीकरण किया जाता है।

EJB को एक्सेस करने के लिए क्लाइंट चलाएं

प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file

नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।

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

ईजेबी उद्यम अनुप्रयोगों का एक हिस्सा है जो आम तौर पर वितरित वातावरण पर आधारित होते हैं। तो, सामान्य अपवादों के अलावा जो हो सकते हैं, संचार विफलता, सुरक्षा अनुमतियाँ, सर्वर डाउन आदि जैसे अपवाद हो सकते हैं।

EJB कंटेनर दो तरह से अपवाद मानता है -

  • Application Exception - यदि व्यापार तर्क का उल्लंघन किया जाता है या व्यापार तर्क निष्पादित करते समय अपवाद होता है।

  • System Exception- कोई भी अपवाद, जो व्यापार तर्क या व्यवसाय कोड के कारण नहीं है। RuntimeException, RemoteException SystemException हैं। उदाहरण के लिए, EJB लुकअप के दौरान त्रुटि। RuntimeException, RemoteException SystemException हैं।

EJB कंटेनर हैंडल अपवाद कैसे होता है?

कब Application Exceptionतब होता है, EJB कंटेनर अपवाद को स्वीकार करता है, लेकिन ग्राहक को वही देता है जो वह है। जब तक यह EJBContext.setRollBackOnly () विधि द्वारा कोड में निर्दिष्ट नहीं किया जाता है, तब तक यह लेनदेन वापस नहीं करता है। EJB कंटेनर अनुप्रयोग अपवाद के मामले में अपवाद को लपेटता नहीं है।

कब System Exceptionतब होता है, EJB कंटेनर अपवाद को स्वीकार करता है, लेन-देन को रोलबैक करता है और सफाई कार्यों को शुरू करता है। यह अपवाद को RemoteException में लपेटता है और क्लाइंट को फेंकता है।

हैंडलिंग अनुप्रयोग अपवाद

आवेदन अपवाद आमतौर पर सत्र EJB विधियों में फेंक दिए जाते हैं क्योंकि ये व्यापारिक तर्क को निष्पादित करने के लिए जिम्मेदार तरीके हैं। आवेदन अपवाद को व्यापार पद्धति के थ्रो क्लॉज में घोषित किया जाना चाहिए और यदि व्यावसायिक तर्क विफल हो जाता है तो उसे फेंक दिया जाना चाहिए।

@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;
   }
   ...
}

हैंडलिंग सिस्टम अपवाद

सिस्टम अपवाद किसी भी समय हो सकता है जैसे कि नामकरण लुकअप विफल रहता है, डेटा लाते समय SQL त्रुटि उत्पन्न होती है। ऐसे मामले में, इस तरह के अपवाद को EJBException के तहत लपेटा जाना चाहिए और क्लाइंट को वापस फेंक दिया जाना चाहिए।

@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;
   }
   ...
}

क्लाइंट की तरफ, 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());
      }
   }
   ...
   }
}

EJB 3.0 सत्र EJB को एक वेबसर्विस के रूप में उजागर करने का विकल्प प्रदान करता है। @WebService एनोटेशन का उपयोग एक वर्ग को वेब सेवा समाप्ति बिंदु के रूप में चिह्नित करने के लिए किया जाता है और @WebMethod का उपयोग क्लाइंट के लिए वेब विधि के रूप में एक विधि को उजागर करने के लिए किया जाता है।

@Stateless
@WebService(serviceName="LibraryService")
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
	
   ...
   @WebMethod(operationName="getBooks")
   public List<Book> getBooks()  {    
      return entityManager.createQuery("From Books").getResultList();
   }
   ...
}

उदाहरण अनुप्रयोग

आइए हम EJB 3.0 में बूँद / क्लोब समर्थन का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।

कदम विवरण
1

EJB में बताए अनुसार एक पैकेज Com.tutorialspoint.entity के तहत EjbComponent नाम से एक प्रोजेक्ट बनाएं - एप्लिकेशन अध्याय बनाएं। कृपया ईजेबी में बनाई गई परियोजना का उपयोग करें - इस अध्याय के रूप में दृढ़ता अध्याय इस प्रकार है कि ईजेबी अवधारणाओं में क्लॉब / बूँद वस्तुओं को समझने के लिए।

2

पैकेज के तहत LibraryPersistentBean.java बनाएं com.tutorialspoint.stateless। संदर्भ के रूप में ईजेबी - दृढ़ता अध्याय का उपयोग करें। बाकी फाइलों को अपरिवर्तित रखें।

3

यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

4

अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा।

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.jws.WebMethod;
import javax.jws.WebService;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
@WebService(serviceName="LibraryService")
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    
   
   @WebMethod(operationName="getBooks")
   public List <Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}

JBoss अनुप्रयोग सर्वर लॉग आउटपुट

10:51:37,271 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibraryPersistentBean ejbName: LibraryPersistentBean
10:51:37,287 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

10:51:37,349 INFO  [EJBContainer] STARTED EJB: com.tuturialspoint.messagebean.LibraryMessageBean ejbName: BookMessageHandler
10:51:37,443 INFO  [DefaultEndpointRegistry] register: jboss.ws:context=EjbComponent,endpoint=LibraryPersistentBean
10:51:38,191 INFO  [WSDLFilePublisher] WSDL published to: file:/D:/Jboss-5.0.1/server/default/data/wsdl/EjbComponent.jar/
LibraryService3853081455302946642.wsdl

EJB को वेब सेवा के रूप में एक्सेस करने के लिए क्लाइंट बनाएं

NetBeans IDE में, चुनें ,File > New Project >श्रेणी के तहत परियोजना के प्रकार का चयन करें।Java, परियोजना का प्रकार Java Application। क्लिकNext >बटन.इंटर प्रोजेक्ट का नाम और स्थान। क्लिकFinish >बटन। हमने नाम EJBWebServiceClient के रूप में चुना है।

प्रोजेक्ट एक्सप्लोरर विंडो में प्रोजेक्ट के नाम पर राइट क्लिक करें। चुनते हैंNew > WebService Client

WSDL और क्लाइंट स्थान का उपयोग करके पहले बनाया गया EJB घटक प्रोजेक्ट का LibraryPersistentBean जोड़ें Add Project में बटन compile टैब।

समाप्त बटन पर क्लिक करें। प्रोजेक्ट एक्सप्लोरर में निम्नलिखित संरचना की जाँच करें।

EJBWebServiceClient.java बनाएँ

package ejbwebserviceclient;

public class EJBWebServiceClient {
   public static void main(String[] args) {   
   }
}

नीचे दिए गए चित्र में दिखाए गए अनुसार वेब सेवा प्राप्त वेबबुक वेब विधि का चयन करें और इसे EJBWebServiceClient की कोड विंडो पर खींचें।

आप नीचे दिखाए गए अनुसार आउटपुट को देखेंगे।

इस विधि का उपयोग करने के लिए EJBWebServiceClient कोड को अपडेट करें।

package ejbwebserviceclient;

public class EJBWebServiceClient {

   public static void main(String[] args) {
      for(com.tutorialspoint.stateless.Book book:getBooks()) {
         System.out.println(book.getName());
      }       
   }

   private static java.util.List
   <com.tutorialspoint.stateless.Book> getBooks() {
      com.tutorialspoint.stateless.LibraryService service = 
         new com.tutorialspoint.stateless.LibraryService();
      com.tutorialspoint.stateless.LibraryPersistentBean port = 
         service.getLibraryPersistentBeanPort();
      return port.getBooks();
   }      
}

क्लाइंट को चलाएँ

प्रोजेक्ट एक्सप्लोरर विंडो में प्रोजेक्ट के नाम पर राइट क्लिक करें। चुनते हैंRun। Netbeans क्लाइंट का निर्माण करेगा और उसे चलाएगा। निम्न आउटपुट सत्यापित करें।

ant -f D:\\SVN\\EJBWebServiceClient run
init:
Deleting: D:\SVN\EJBWebServiceClient\build\built-jar.properties
deps-jar:
Updating property file: D:\SVN\EJBWebServiceClient\build\built-jar.properties
wsimport-init:
wsimport-client-LibraryPersistentBean:
files are up to date
classLoader = java.net.URLClassLoader@4ce46c
SharedSecrets.getJavaNetAccess()=java.net.URLClassLoader$7@182cdac
wsimport-client-generate:
Compiling 1 source file to D:\SVN\EJBWebServiceClient\build\classes
compile:
run:
learn java
Learn Spring
learn JSF
Learn HTML
Learn JBoss
Learn EJB
Learn Hibernate
Learn IBatis
Times Now
learn html5
Learn images
Learn Testing
Forbes
test1
BUILD SUCCESSFUL (total time: 1 second)

EJB 3.0 का उपयोग कर पैकेजिंग अनुप्रयोगों की आवश्यकता J2EE प्लेटफ़ॉर्म के समान है। EJB घटकों को जार फ़ाइलों के रूप में मॉड्यूल में पैक किया जाता है और इसे कान के फ़ाइल के रूप में एप्लिकेशन एंटरप्राइज आर्काइव में पैक किया जाता है।

किसी भी उद्यम अनुप्रयोग के तीन प्रमुख घटक हैं -

  • jar - जावा एप्लीकेशन आराइविव, जिसमें ईजेबी मॉड्यूल, ईजेबी क्लाइंट मॉड्यूल और यूटिलिटी मॉड्यूल शामिल हैं।

  • war - वेब एप्लीकेशन आरचीव, वेब मॉड्यूल युक्त।

  • ear - एंटरप्राइज एप्लिकेशन आरचीव, जार और युद्ध मॉड्यूल युक्त।

NetBeans में, J2EE एप्लिकेशन बनाना, विकसित करना, पैकेज करना और उनकी तैनाती करना बहुत आसान है।

NetBeans IDE में, चुनें,File > New Project >श्रेणी के तहत परियोजना के प्रकार का चयन करें।Java EE, परियोजना का प्रकार Enterprise Application। क्लिकNext >बटन। प्रोजेक्ट का नाम और स्थान दर्ज करें। क्लिकFinish >बटन। हमने EnterpriseApplicaton के रूप में नाम चुना है।

सर्वर और सेटिंग्स का चयन करें। रखनाCreate EJB Module तथा Create Web Application Moduleप्रदान किए गए डिफ़ॉल्ट नामों के साथ जाँच की गई। फिनिश बटन पर क्लिक करें। NetBeans प्रोजेक्ट विंडो में निम्नलिखित संरचना बनाएगा।

प्रोजेक्ट पर राइट क्लिक करें Enterprise Application प्रोजेक्ट एक्सप्लोरर में और बिल्ड चुनें।

ant -f D:\\SVN\\EnterpriseApplication dist
pre-init:
init-private:
init-userdir:
init-user:
init-project:
do-init:
post-init:
init-check:
init:
deps-jar:
deps-j2ee-archive:
EnterpriseApplication-ejb.init:
EnterpriseApplication-ejb.deps-jar:
EnterpriseApplication-ejb.compile:
EnterpriseApplication-ejb.library-inclusion-in-manifest:

Building jar: D:\SVN\EnterpriseApplication\EnterpriseApplication-ejb\dist\EnterpriseApplication-ejb.jar

EnterpriseApplication-ejb.dist-ear:
EnterpriseApplication-war.init:
EnterpriseApplication-war.deps-module-jar:
EnterpriseApplication-war.deps-ear-jar:
EnterpriseApplication-ejb.init:
EnterpriseApplication-ejb.deps-jar:
EnterpriseApplication-ejb.compile:
EnterpriseApplication-ejb.library-inclusion-in-manifest:
EnterpriseApplication-ejb.dist-ear:
EnterpriseApplication-war.deps-jar:
EnterpriseApplication-war.library-inclusion-in-archive:
EnterpriseApplication-war.library-inclusion-in-manifest:
EnterpriseApplication-war.compile:
EnterpriseApplication-war.compile-jsps:
EnterpriseApplication-war.do-ear-dist:

Building jar: D:\SVN\EnterpriseApplication\EnterpriseApplication-war\dist\EnterpriseApplication-war.war

EnterpriseApplication-war.dist-ear:
pre-pre-compile:
pre-compile:
Copying 1 file to D:\SVN\EnterpriseApplication\build
Copying 1 file to D:\SVN\EnterpriseApplication\build
do-compile:
post-compile:
compile:
pre-dist:
do-dist-without-manifest:
do-dist-with-manifest:

Building jar: D:\SVN\EnterpriseApplication\dist\EnterpriseApplication.ear

post-dist:
dist:
BUILD SUCCESSFUL (total time: 1 second)

यहाँ आप देख सकते हैं, कि नेटबीन्स जार को पहले तैयार करता है, फिर युद्ध और अंत में, जार और युद्ध को ले जाने वाली कान फाइल, फ़ाइल। प्रत्येक जार, युद्ध और कान की फाइल ameta-inf J2EE विनिर्देश के अनुसार मेटा डेटा के लिए फ़ोल्डर।