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.