JSP - İfade Dili (EL)

JSP İfade Dili (EL), JavaBeans bileşenlerinde depolanan uygulama verilerine kolayca erişmeyi mümkün kılar. JSP EL, hem ifadeler oluşturmanıza olanak tanır(a) aritmetik ve (b)mantıklı. Bir JSP EL ifadesi içinde kullanabilirsinizintegers, floating point numbers, strings, the built-in constants true and false boole değerleri için ve null.

Basit Sözdizimi

Tipik olarak, bir JSP etiketinde bir öznitelik değeri belirttiğinizde, yalnızca bir dize kullanırsınız. Örneğin -

<jsp:setProperty name = "box" property = "perimeter" value = "100"/>

JSP EL, bu öznitelik değerlerinden herhangi biri için bir ifade belirlemenize izin verir. JSP EL için basit bir sözdizimi aşağıdaki gibidir -

${expr}

Buraya exprifadenin kendisini belirtir. JSP EL'deki en yaygın operatörler:. ve []. Bu iki operatör, çeşitli Java Beans özelliklerine ve yerleşik JSP nesnelerine erişmenizi sağlar.

Örneğin, yukarıdaki sözdizimi <jsp:setProperty> etiketi gibi bir ifade ile yazılabilir -

<jsp:setProperty name = "box" property = "perimeter" 
   value = "${2*box.width+2*box.height}"/>

JSP derleyici, ${} form bir öznitelikte, ifadeyi değerlendirmek için kod üretir ve expresson değerini değiştirir.

JSP EL ifadelerini bir etiket için şablon metni içinde de kullanabilirsiniz. Örneğin,<jsp:text>etiketi, içeriğini bir JSP gövdesine ekler. Aşağıdaki<jsp:text> beyanname ekler <h1>Hello JSP!</h1> JSP çıktısına -

<jsp:text>
   <h1>Hello JSP!</h1>
</jsp:text>

Artık bir JSP EL ifadesini bir <jsp:text> aynı olan etiket (veya başka bir etiket) ${}öznitelikler için kullandığınız sözdizimi. Örneğin -

<jsp:text>
   Box Perimeter is: ${2*box.width + 2*box.height}
</jsp:text>

EL ifadeleri, alt ifadeleri gruplamak için parantez kullanabilir. Örneğin,${(1 + 2) * 3} equals 9, but ${1 + (2 * 3)} equals 7.

EL ifadelerinin değerlendirmesini devre dışı bırakmak için, isELIgnored aşağıdaki gibi sayfa yönergesinin özniteliği -

<%@ page isELIgnored = "true|false" %>

Bu niteliğin geçerli değerleri doğru ve yanlıştır. Doğruysa, EL ifadeleri statik metin veya etiket özniteliklerinde göründüklerinde yok sayılır. Yanlışsa, EL ifadeleri konteyner tarafından değerlendirilir.

EL'de Temel Operatörler

JSP İfade Dili (EL), Java tarafından desteklenen aritmetik ve mantıksal operatörlerin çoğunu destekler. Aşağıdaki tablo en sık kullanılan operatörleri listeler -

S.No. Operatör ve Açıklama
1

.

Fasulye mülküne veya Harita girişine erişin

2

[]

Bir diziye veya Liste öğesine erişin

3

( )

Değerlendirme sırasını değiştirmek için bir alt ifadeyi gruplayın

4

+

İlave

5

-

Bir değerin çıkarılması veya olumsuzlanması

6

*

Çarpma işlemi

7

/ or div

Bölünme

8

% or mod

Modulo (kalan)

9

== or eq

Eşitlik testi

10

!= or ne

Eşitsizlik testi

11

< or lt

Şundan azını test edin:

12

> or gt

Daha fazlası için test edin

13

<= or le

Küçük veya eşit için test edin

14

>= or ge

Büyük veya eşit olup olmadığını test edin

15

&& or and

Mantıksal AND için test edin

16

|| or or

Mantıksal VEYA testi

17

! or not

Tekli Boole tamamlayıcı

18

empty

Boş değişken değerleri için test edin

JSP EL'deki Fonksiyonlar

JSP EL, ifadelerde de fonksiyonları kullanmanıza izin verir. Bu işlevler, özel etiket kitaplıklarında tanımlanmalıdır. Bir işlev kullanımı aşağıdaki sözdizimine sahiptir -

${ns:func(param1, param2, ...)}

Nerede ns işlevin ad alanıdır, func işlevin adıdır ve param1ilk parametre değeridir. Örneğin, işlevfn:lengthJSTL kitaplığının bir parçası olan. Bu işlev, bir dizenin uzunluğunu elde etmek için aşağıdaki şekilde kullanılabilir.

${fn:length("Get my length")}

Herhangi bir etiket kitaplığından (standart veya özel) bir işlevi kullanmak için, bu kitaplığı sunucunuza yüklemeli ve kitaplığı JSP'nize eklemelisiniz. <taglib> yönergesi JSTL bölümünde açıklandığı gibidir.

JSP EL Örtük Nesneler

JSP ifade dili aşağıdaki örtük nesneleri destekler -

S.No Örtülü nesne ve Açıklama
1

pageScope

Sayfa kapsamından kapsamlı değişkenler

2

requestScope

İstek kapsamındaki kapsamlı değişkenler

3

sessionScope

Oturum kapsamındaki kapsamlı değişkenler

4

applicationScope

Uygulama kapsamındaki kapsamlı değişkenler

5

param

Parametreleri dizeler olarak isteyin

6

paramValues

Dize koleksiyonları olarak parametreler isteme

7

header

Dizeler olarak HTTP istek başlıkları

8

headerValues

Dizelerin koleksiyonları olarak HTTP istek başlıkları

9

initParam

Bağlam başlatma parametreleri

10

cookie

Çerez değerleri

11

pageContext

Geçerli sayfa için JSP PageContext nesnesi

Bu nesneleri değişkenlermiş gibi bir ifadede kullanabilirsiniz. Aşağıdaki örnekler, kavramları anlamanıza yardımcı olacaktır -

PageContext Nesnesi

PageContext nesnesi, pageContext JSP nesnesine erişmenizi sağlar. PageContext nesnesi aracılığıyla, istek nesnesine erişebilirsiniz. Örneğin, bir istek için gelen sorgu dizesine erişmek için aşağıdaki ifadeyi kullanabilirsiniz -

${pageContext.request.queryString}

Kapsam Nesneleri

pageScope, requestScope, sessionScope, ve applicationScope değişkenler, her kapsam düzeyinde depolanan değişkenlere erişim sağlar.

Örneğin, uygulama kapsamındaki kutu değişkenine açıkça erişmeniz gerekiyorsa, buna applicationScope değişkeni aracılığıyla şu şekilde erişebilirsiniz: applicationScope.box.

Param ve paramValues ​​Nesneleri

Param ve paramValues ​​nesneleri, normalde mevcut olan parametre değerlerine erişmenizi sağlar. request.getParameter ve request.getParameterValues yöntemler.

Örneğin, order adlı bir parametreye erişmek için şu ifadeyi kullanın: ${param.order} veya ${param["order"]}.

Username adlı bir istek parametresine erişim örneği aşağıdadır -

<%@ 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>

Param nesnesi tek dize değerlerini döndürürken, paramValues ​​nesnesi dize dizilerini döndürür.

başlık ve başlıkValues ​​Nesneleri

Header ve headerValues ​​nesneleri, normalde mevcut olan başlık değerlerine erişmenizi sağlar. request.getHeader ve request.getHeaders yöntemler.

Örneğin, kullanıcı aracısı adlı bir başlığa erişmek için ifadesini kullanın ${header.user-agent} veya ${header["user-agent"]}.

Kullanıcı aracısı adlı bir başlık parametresine erişim örneği aşağıdadır -

<%@ 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>

Çıktı bir şekilde aşağıdaki gibi olacaktır -

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)

Başlık nesnesi tek dize değerlerini döndürürken, headerValues ​​nesnesi dize dizilerini döndürür.