ईजेबी - त्वरित गाइड
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
|
2 | javax.ejb.Stateful |
निर्दिष्ट करता है कि एक दिया गया EJB वर्ग एक स्टेटफुल सेशन बीन है। Attributes
|
3 | javax.ejb.MessageDrivenBean |
निर्दिष्ट करता है कि एक दिए गए EJB वर्ग एक संदेश संचालित बीन है। Attributes
|
4 | javax.ejb.EJB |
एक निर्भरता को अन्य EJB में EJB उदाहरण के रूप में निर्दिष्ट या इंजेक्ट करने के लिए उपयोग किया जाता है। Attributes
|
5 | javax.ejb.Local |
एक सत्र बीन के स्थानीय इंटरफ़ेस (एस) को निर्दिष्ट करने के लिए उपयोग किया जाता है। यह स्थानीय इंटरफ़ेस सत्र बीन (जो स्टेटलेस या स्टेटफुल हो सकता है) के व्यापारिक तरीकों को बताता है। इस इंटरफ़ेस का उपयोग स्थानीय ग्राहकों के लिए व्यावसायिक विधियों को उजागर करने के लिए किया जाता है, जो EJB के समान तैनाती / आवेदन में चल रहे हैं। Attributes
|
6 | javax.ejb.Remote |
एक सत्र बीन के रिमोट इंटरफेस (एस) को निर्दिष्ट करने के लिए उपयोग किया जाता है। यह दूरस्थ इंटरफ़ेस सत्र बीन (जो स्टेटलेस या स्टेटफुल हो सकता है) के व्यापारिक तरीकों को बताता है। इस इंटरफ़ेस का उपयोग दूरस्थ क्लाइंट्स के लिए व्यापारिक विधियों को उजागर करने के लिए किया जाता है, जो EJB के रूप में विभिन्न तैनाती / अनुप्रयोग में चल रहे हैं। Attributes
|
7 | javax.ejb.Activation ConfigProperty |
एक संदेश संचालित बीन के लिए आवश्यक गुणों को निर्दिष्ट करने के लिए उपयोग किया जाता है। उदाहरण के लिए, अंतिम बिंदु, गंतव्य, संदेश चयनकर्ता आदि। यह एनोटेशन javax.ejb.MessageDrivenBean एनोटेशन के सक्रियण विशेषता के पैरामीटर के रूप में पारित किया जाता है। Attributes
|
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 विनिर्देश के अनुसार मेटा डेटा के लिए फ़ोल्डर।