JSP - अभिव्यक्ति भाषा (ईएल)
जेएसपी एक्सप्रेशन लैंग्वेज (ईएल) जावाबिन घटकों में संग्रहीत एप्लिकेशन डेटा को आसानी से एक्सेस करना संभव बनाता है। जेएसपी ईएल आपको अभिव्यक्ति दोनों बनाने की अनुमति देता है(a) अंकगणित और (b)तार्किक। एक JSP ईएल अभिव्यक्ति के भीतर, आप उपयोग कर सकते हैंintegers, floating point numbers, strings, the built-in constants true and false बूलियन मूल्यों के लिए, और अशक्त।
सिंपल सिंटेक्स
आमतौर पर, जब आप JSP टैग में विशेषता मान निर्दिष्ट करते हैं, तो आप बस एक स्ट्रिंग का उपयोग करते हैं। उदाहरण के लिए -
<jsp:setProperty name = "box" property = "perimeter" value = "100"/>
JSP EL आपको इनमें से किसी भी विशेषता मान के लिए एक अभिव्यक्ति निर्दिष्ट करने की अनुमति देता है। JSP EL के लिए एक सरल वाक्यविन्यास निम्नानुसार है -
${expr}
यहाँ exprस्वयं अभिव्यक्ति निर्दिष्ट करता है। जेएसपी ईएल में सबसे आम ऑपरेटर हैं. तथा []। ये दो ऑपरेटर आपको जावा बीन्स और अंतर्निहित जेएसपी ऑब्जेक्ट्स की विभिन्न विशेषताओं तक पहुंचने की अनुमति देते हैं।
उदाहरण के लिए, उपरोक्त सिंटैक्स <jsp:setProperty> टैग को अभिव्यक्ति के साथ लिखा जा सकता है जैसे -
<jsp:setProperty name = "box" property = "perimeter"
value = "${2*box.width+2*box.height}"/>
जब JSP संकलक देखता है ${} एक विशेषता के रूप में, यह अभिव्यक्ति का मूल्यांकन करने के लिए कोड उत्पन्न करता है और एक्सप्रेसन के मूल्य को प्रतिस्थापित करता है।
आप टैग के लिए टेम्प्लेट पाठ के भीतर JSP EL अभिव्यक्तियों का भी उपयोग कर सकते हैं। उदाहरण के लिए,<jsp:text>टैग केवल एक JSP के शरीर के भीतर अपनी सामग्री सम्मिलित करता है। निम्नलिखित<jsp:text> घोषणा आवेषण <h1>Hello JSP!</h1> JSP आउटपुट में -
<jsp:text>
<h1>Hello JSP!</h1>
</jsp:text>
अब आप एक के शरीर में JSP EL अभिव्यक्ति को शामिल कर सकते हैं <jsp:text> टैग (या कोई अन्य टैग) उसी के साथ ${}सिंटैक्स आप विशेषताओं के लिए उपयोग करते हैं। उदाहरण के लिए -
<jsp:text>
Box Perimeter is: ${2*box.width + 2*box.height}
</jsp:text>
ईएल अभिव्यक्तियाँ कोष्ठक का उपयोग समूह उपमेक्शन्स में कर सकती हैं। उदाहरण के लिए,${(1 + 2) * 3} equals 9, but ${1 + (2 * 3)} equals 7।
ईएल अभिव्यक्तियों के मूल्यांकन को निष्क्रिय करने के लिए, हम निर्दिष्ट करते हैं isELIgnored नीचे दिए गए पृष्ठ निर्देश की विशेषता -
<%@ page isELIgnored = "true|false" %>
इस विशेषता के मान्य मूल्य सच्चे और झूठे हैं। यदि यह सत्य है, तो स्थिर पाठ या टैग विशेषताओं में ईएल अभिव्यक्तियों को अनदेखा किया जाता है। यदि यह गलत है, तो EL अभिव्यक्तियों का मूल्यांकन कंटेनर द्वारा किया जाता है।
ईएल में मूल संचालक
JSP एक्सप्रेशन लैंग्वेज (EL) जावा द्वारा समर्थित अधिकांश अंकगणित और तार्किक ऑपरेटरों का समर्थन करती है। निम्नलिखित तालिका सबसे अधिक इस्तेमाल किए जाने वाले ऑपरेटरों की सूची बनाती है -
क्र.सं. | ऑपरेटर और विवरण |
---|---|
1 | . एक बीन संपत्ति या मानचित्र प्रविष्टि तक पहुंचें |
2 | [] किसी ऐरे या सूची तत्व तक पहुँचें |
3 | ( ) मूल्यांकन आदेश को बदलने के लिए एक सबडिफ़ॉर्मेशन समूह |
4 | + इसके अलावा |
5 | - किसी मूल्य का घटाव या निषेध |
6 | * गुणा |
7 | / or div विभाजन |
8 | % or mod मोडुलो (शेष) |
9 | == or eq समानता के लिए परीक्षण करें |
10 | != or ne असमानता के लिए परीक्षण |
1 1 | < or lt से कम के लिए टेस्ट करें |
12 | > or gt से अधिक के लिए टेस्ट |
13 | <= or le कम या बराबर के लिए टेस्ट करें |
14 | >= or ge से अधिक या बराबर के लिए टेस्ट |
15 | && or and तार्किक और के लिए टेस्ट |
16 | || or or तार्किक OR के लिए टेस्ट |
17 | ! or not यूनिली बूलियन पूरक |
18 | empty रिक्त चर मानों के लिए परीक्षण करें |
जेएसपी ईएल में कार्य
जेएसपी ईएल आपको अभिव्यक्ति में भी कार्यों का उपयोग करने की अनुमति देता है। इन कार्यों को कस्टम टैग लाइब्रेरी में परिभाषित किया जाना चाहिए। एक फ़ंक्शन उपयोग में निम्न सिंटैक्स होता है -
${ns:func(param1, param2, ...)}
कहाँ पे ns फ़ंक्शन का नाम स्थान है, func फ़ंक्शन का नाम है और param1पहला पैरामीटर मान है। उदाहरण के लिए, फ़ंक्शनfn:length, जो JSTL लाइब्रेरी का हिस्सा है। इस फ़ंक्शन का उपयोग स्ट्रिंग की लंबाई प्राप्त करने के लिए निम्नानुसार किया जा सकता है।
${fn:length("Get my length")}
किसी भी टैग लाइब्रेरी (मानक या कस्टम) से किसी फ़ंक्शन का उपयोग करने के लिए, आपको अपने सर्वर पर उस लाइब्रेरी को स्थापित करना होगा और इसमें अपने लाइब्रेरी को लाइब्रेरी में शामिल करना होगा <taglib> JSTL चैप्टर में बताया गया निर्देश।
JSP EL निहित वस्तुएं
JSP अभिव्यक्ति भाषा निम्नलिखित निहित वस्तुओं का समर्थन करती है -
S.No | निहित वस्तु और विवरण |
---|---|
1 | pageScope पृष्ठ स्कोप से भिन्न चर |
2 | requestScope अनुरोध क्षेत्र से भिन्न चर |
3 | sessionScope सत्र स्कोप से भिन्न चर |
4 | applicationScope अनुप्रयोग स्कोप से भिन्न चर |
5 | param स्ट्रिंग के रूप में मापदंडों का अनुरोध करें |
6 | paramValues स्ट्रिंग के संग्रह के रूप में मापदंडों का अनुरोध करें |
7 | header HTTP अनुरोध हेडर को स्ट्रिंग्स के रूप में |
8 | headerValues HTTP स्ट्रिंग्स के संग्रह के रूप में हेडर का अनुरोध करता है |
9 | initParam प्रसंग-आरंभिक मापदंड |
10 | cookie कुकी का मान |
1 1 | pageContext वर्तमान पृष्ठ के लिए JSP PageContext ऑब्जेक्ट |
आप इन वस्तुओं को एक अभिव्यक्ति में उपयोग कर सकते हैं जैसे कि वे चर थे। पालन करने वाले उदाहरण आपको अवधारणाओं को समझने में मदद करेंगे -
PageContext ऑब्जेक्ट
PageContext ऑब्जेक्ट आपको PageContext JSP ऑब्जेक्ट तक पहुँच प्रदान करता है। पेज कॉन्टेक्स्ट ऑब्जेक्ट के माध्यम से, आप अनुरोध ऑब्जेक्ट तक पहुंच सकते हैं। उदाहरण के लिए, किसी अनुरोध के लिए आने वाली क्वेरी स्ट्रिंग तक पहुंचने के लिए, आप निम्नलिखित अभिव्यक्ति का उपयोग कर सकते हैं -
${pageContext.request.queryString}
स्कोप ऑब्जेक्ट्स
pageScope, requestScope, sessionScope, तथा applicationScope चर प्रत्येक गुंजाइश स्तर पर संग्रहीत चर तक पहुँच प्रदान करते हैं।
उदाहरण के लिए, यदि आपको एप्लिकेशन स्कोप में बॉक्स वैरिएबल को स्पष्ट रूप से एक्सेस करने की आवश्यकता है, तो आप इसे एप्लीकेशन के माध्यम से एक्सेस कर सकते हैं। applicationScope.box।
परम और परमलव्स वस्तुओं
Param और paramValues ऑब्जेक्ट आपको सामान्य रूप से उपलब्ध पैरामीटर मानों तक पहुंच प्रदान करते हैं request.getParameter तथा request.getParameterValues तरीकों।
उदाहरण के लिए, ऑर्डर नाम के पैरामीटर तक पहुंचने के लिए, अभिव्यक्ति का उपयोग करें ${param.order} या ${param["order"]}।
उपयोगकर्ता नाम नामक अनुरोध पैरामीटर तक पहुंचने के लिए उदाहरण निम्नलिखित है -
<%@ page import = "java.io.*,java.util.*" %>
<%String title = "Accessing Request Param";%>
<html>
<head>
<title><% out.print(title); %></title>
</head>
<body>
<center>
<h1><% out.print(title); %></h1>
</center>
<div align = "center">
<p>${param["username"]}</p>
</div>
</body>
</html>
परम ऑब्जेक्ट सिंगल स्ट्रिंग मान लौटाता है, जबकि परमल्यूज़ ऑब्जेक्ट स्ट्रिंग सरणियाँ देता है।
शीर्ष लेख और शीर्ष लेख ऑब्जेक्ट्स
हेडर और हेडरवैल्यू ऑब्जेक्ट्स आपको हेडर के मूल्यों तक पहुंच प्रदान करते हैं जो सामान्य रूप से उपलब्ध हैं request.getHeader और यह request.getHeaders तरीकों।
उदाहरण के लिए, उपयोगकर्ता-एजेंट नाम के हेडर तक पहुंचने के लिए, अभिव्यक्ति का उपयोग करें ${header.user-agent} या ${header["user-agent"]}।
उपयोगकर्ता-एजेंट नाम के हेडर पैरामीटर तक पहुंचने के लिए निम्नलिखित उदाहरण है -
<%@ page import = "java.io.*,java.util.*" %>
<%String title = "User Agent Example";%>
<html>
<head>
<title><% out.print(title); %></title>
</head>
<body>
<center>
<h1><% out.print(title); %></h1>
</center>
<div align = "center">
<p>${header["user-agent"]}</p>
</div>
</body>
</html>
उत्पादन कुछ हद तक निम्नलिखित की तरह होगा -
User Agent Example
Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; HPNTDF; .NET4.0C; InfoPath.2)
शीर्ष लेख ऑब्जेक्ट एकल स्ट्रिंग मान देता है, जबकि शीर्ष लेख ऑब्जेक्ट ऑब्जेक्ट स्ट्रिंग स्ट्रिंग देता है।