JSP - Eylemler
Bu bölümde, JSP'deki Eylemleri tartışacağız. Bu eylemler, sunucu uygulaması motorunun davranışını kontrol etmek için XML sözdizimindeki yapıları kullanır. Dinamik olarak bir dosya ekleyebilir, JavaBeans bileşenlerini yeniden kullanabilir, kullanıcıyı başka bir sayfaya iletebilir veya Java eklentisi için HTML oluşturabilirsiniz.
XML standardına uyduğundan Action öğesi için yalnızca bir sözdizimi vardır -
<jsp:action_name attribute = "value" />
Eylem öğeleri temelde önceden tanımlanmış işlevlerdir. Aşağıdaki tablo, mevcut JSP eylemlerini listeler -
S.No. | Sözdizimi ve Amaç |
---|---|
1 | jsp:include Sayfanın istendiği anda bir dosya içerir. |
2 | jsp:useBean Bir JavaBean bulur veya örneğini oluşturur. |
3 | jsp:setProperty JavaBean'ın özelliğini ayarlar. |
4 | jsp:getProperty Bir JavaBean özelliğini çıktıya ekler. |
5 | jsp:forward İstekte bulunan kişiyi yeni bir sayfaya yönlendirir. |
6 | jsp:plugin Java eklentisi için OBJECT veya EMBED etiketi oluşturan tarayıcıya özgü kod üretir. |
7 | jsp:element XML öğelerini dinamik olarak tanımlar. |
8 | jsp:attribute Dinamik olarak tanımlanmış XML öğesinin niteliğini tanımlar. |
9 | jsp:body Dinamik olarak tanımlanmış XML öğesinin gövdesini tanımlar. |
10 | jsp:text JSP sayfalarında ve belgelerde şablon metni yazmak için kullanılır. |
Ortak Özellikler
Tüm Eylem öğelerinde ortak olan iki özellik vardır: id öznitelik ve scope öznitelik.
Kimlik özelliği
İd özniteliği, Action öğesini benzersiz şekilde tanımlar ve eyleme JSP sayfası içinde başvurulmasına izin verir. Eylem bir nesnenin bir örneğini oluşturursa, id değeri örtülü nesne PageContext aracılığıyla ona başvurmak için kullanılabilir.
Kapsam özelliği
Bu öznitelik, Action öğesinin yaşam döngüsünü tanımlar. İd özniteliği ve kapsam özniteliği, id ile ilişkilendirilmiş nesnenin ömrünü belirlediğinden, doğrudan ilişkilidir. Scope özniteliğinin dört olası değeri vardır:(a) page, (b)request, (c)session, ve (d) application.
<Jsp: include> İşlemi
Bu eylem, oluşturulan sayfaya dosya eklemenizi sağlar. Sözdizimi şuna benzer -
<jsp:include page = "relative URL" flush = "true" />
Aksine include JSP sayfası bir sunucu uygulamasına çevrildiğinde dosyayı ekleyen yönergesi, bu eylem dosyayı sayfanın istendiği anda ekler.
Aşağıdaki tablo, içerme eylemiyle ilişkili öznitelikleri listeler -
S.No. | Öznitelik ve Açıklama |
---|---|
1 | page Dahil edilecek sayfanın göreli URL'si. |
2 | flush Boolean niteliği, dahil edilen kaynağın eklenmeden önce tamponunun temizlenmiş olup olmadığını belirler. |
Misal
Aşağıdaki iki dosyayı tanımlayalım (a)date.jsp ve (b) main.jsp aşağıdaki gibi -
Aşağıdakilerin içeriği date.jsp dosya -
<p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>
Aşağıdakilerin içeriği main.jsp dosya -
<html>
<head>
<title>The include Action Example</title>
</head>
<body>
<center>
<h2>The include action Example</h2>
<jsp:include page = "date.jsp" flush = "true" />
</center>
</body>
</html>
Şimdi tüm bu dosyaları kök dizinde tutalım ve erişmeye çalışalım. main.jsp. Aşağıdaki çıktıyı alacaksınız -
The include action Example
Today's date: 12-Sep-2010 14:54:22
<Jsp: useBean> Eylemi
useBeaneylem oldukça çok yönlüdür. Önce id ve kapsam değişkenlerini kullanarak mevcut bir nesneyi arar. Bir nesne bulunamazsa, belirtilen nesneyi oluşturmaya çalışır.
Bir fasulyeyi yüklemenin en basit yolu aşağıdaki gibidir -
<jsp:useBean id = "name" class = "package.class" />
Bir bean sınıfı yüklendikten sonra şunu kullanabilirsiniz: jsp:setProperty ve jsp:getProperty fasulye özelliklerini değiştirme ve alma eylemleri.
Aşağıdaki tablo useBean eylemiyle ilişkili öznitelikleri listeler -
S.No. | Öznitelik ve Açıklama |
---|---|
1 | class Çekirdeğin tam paket adını belirtir. |
2 | type Nesneye başvuracak değişkenin türünü belirtir. |
3 | beanName Java.beans.Beans sınıfının instantiate () yöntemi tarafından belirtildiği şekilde çekirdeğin adını verir. |
Şimdi tartışalım jsp:setProperty ve jsp:getProperty bu eylemlerle ilgili geçerli bir örnek vermeden önce eylemler.
<Jsp: setProperty> Eylemi
setPropertyeylem bir Bean öğesinin özelliklerini ayarlar. Bean, bu eylemden önce önceden tanımlanmış olmalıdır. SetProperty eylemini kullanmanın iki temel yolu vardır -
Kullanabilirsiniz jsp:setProperty sonra, ama dışında jsp:useBean element, aşağıda verildiği gibi -
<jsp:useBean id = "myName" ... />
...
<jsp:setProperty name = "myName" property = "someProperty" .../>
Bu durumda, jsp:setProperty yeni bir çekirdeğin somutlaştırılmış veya mevcut bir çekirdek bulunmuş olup olmadığına bakılmaksızın yürütülür.
Jsp: setProperty'nin görünebileceği ikinci bir bağlam, bir jsp:useBean element, aşağıda verildiği gibi -
<jsp:useBean id = "myName" ... >
...
<jsp:setProperty name = "myName" property = "someProperty" .../>
</jsp:useBean>
Burada jsp: setProperty yalnızca yeni bir nesne somutlaştırılmışsa çalıştırılır, mevcut bir nesne bulunursa çalıştırılmaz.
Aşağıdaki tablo, ile ilişkili öznitelikleri listeler. setProperty eylem -
S.No. | Öznitelik ve Açıklama |
---|---|
1 | name Özelliği ayarlanacak fasulyeyi belirtir. Bean önceden tanımlanmış olmalıdır. |
2 | property Ayarlamak istediğiniz özelliği gösterir. "*" Değeri, adları bean özellik adlarıyla eşleşen tüm istek parametrelerinin uygun ayarlayıcı yöntemlerine aktarılacağı anlamına gelir. |
3 | value Verilen özelliğe atanacak değer. Parametrenin değeri boş veya parametre mevcut değil, setProperty eylemi yok sayılır. |
4 | param Param özniteliği, değeri özelliğin alacağı istek parametresinin adıdır. Hem değeri hem de paramı kullanamazsınız, ancak ikisini de kullanmanıza izin verilmez. |
<Jsp: getProperty> İşlemi
getProperty action, belirli bir özelliğin değerini almak için kullanılır ve bunu bir dizeye dönüştürür ve son olarak çıktıya ekler.
GetProperty eyleminin yalnızca iki özelliği vardır ve her ikisi de gereklidir. GetProperty eyleminin sözdizimi aşağıdaki gibidir -
<jsp:useBean id = "myName" ... />
...
<jsp:getProperty name = "myName" property = "someProperty" .../>
Aşağıdaki tablo ile ilişkili gerekli öznitelikler listelenmektedir. getProperty eylem -
S.No. | Öznitelik ve Açıklama |
---|---|
1 | name Alınacak bir özelliğe sahip olan Fasulyenin adı. Bean önceden tanımlanmış olmalıdır. |
2 | property Özellik özniteliği, alınacak Bean özelliğinin adıdır. |
Misal
Örneğimizde daha sonra kullanılacak bir test çekirdeği tanımlayalım -
/* File: TestBean.java */
package action;
public class TestBean {
private String message = "No message specified";
public String getMessage() {
return(message);
}
public void setMessage(String message) {
this.message = message;
}
}
Yukarıdaki kodu oluşturulan TestBean.class dosyasını açın ve TestBean.class'ı kopyaladığınızdan emin olun. C:\apache-tomcat-7.0.2\webapps\WEB-INF\classes\action klasör ve CLASSPATH değişken de bu klasöre ayarlanmalıdır -
Şimdi aşağıdaki kodu kullanın main.jspdosya. Bu, fasulyeyi yükler ve basit bir String parametresi ayarlar / alır -
<html>
<head>
<title>Using JavaBeans in JSP</title>
</head>
<body>
<center>
<h2>Using JavaBeans in JSP</h2>
<jsp:useBean id = "test" class = "action.TestBean" />
<jsp:setProperty name = "test" property = "message"
value = "Hello JSP..." />
<p>Got message....</p>
<jsp:getProperty name = "test" property = "message" />
</center>
</body>
</html>
Şimdi erişmeyi deneyelim main.jsp, şu sonucu gösterecektir -
Using JavaBeans in JSP
Got message.... Hello JSP...
<Jsp: forward> İşlemi
forward eylem, geçerli sayfanın eylemini sonlandırır ve isteği statik bir sayfa, başka bir JSP sayfası veya bir Java Servlet gibi başka bir kaynağa iletir.
Aşağıdaki sözdizimi forward eylem -
<jsp:forward page = "Relative URL" />
Aşağıdaki tablo, yönlendirme işlemiyle ilişkili gerekli öznitelikleri listeler -
S.No. | Öznitelik ve Açıklama |
---|---|
1 | page Statik bir sayfa, başka bir JSP sayfası veya bir Java Servlet gibi başka bir kaynağın göreli URL'sinden oluşmalıdır. |
Misal
Aşağıdaki iki dosyayı yeniden kullanalım (a) date.jsp ve (b) main.jsp aşağıdaki gibi -
Aşağıdakilerin içeriği date.jsp dosya -
<p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>
Aşağıdakilerin içeriği main.jsp dosya -
<html>
<head>
<title>The include Action Example</title>
</head>
<body>
<center>
<h2>The include action Example</h2>
<jsp:forward page = "date.jsp" />
</center>
</body>
</html>
Şimdi tüm bu dosyaları kök dizinde tutalım ve erişmeye çalışalım. main.jsp. Bu, aşağıdaki gibi bir sonuç gösterecektir.
Burada ana sayfadaki içeriği attı ve içeriği yalnızca yönlendirilen sayfadan görüntüledi.
Today's date: 12-Sep-2010 14:54:22
<Jsp: eklenti> Eylem
plugineylem, Java bileşenlerini bir JSP sayfasına eklemek için kullanılır. Tarayıcının türünü belirler ve<object> veya <embed> etiketleri gerektiği gibi.
Gerekli eklenti mevcut değilse, eklentiyi indirir ve ardından Java bileşenini çalıştırır. Java bileşeni bir Applet veya JavaBean olabilir.
Eklenti eylemi, Java bileşenlerini biçimlendirmek için kullanılan yaygın HTML etiketlerine karşılık gelen birkaç niteliğe sahiptir. <param> öğesi, parametreleri Applet veya Bean'e göndermek için de kullanılabilir.
Eklenti eylemini kullanmanın tipik sözdizimi aşağıdadır -
<jsp:plugin type = "applet" codebase = "dirname" code = "MyApplet.class"
width = "60" height = "80">
<jsp:param name = "fontcolor" value = "red" />
<jsp:param name = "background" value = "black" />
<jsp:fallback>
Unable to initialize Java Plugin
</jsp:fallback>
</jsp:plugin>
Eğer ilgileniyorsanız bu eylemi bazı uygulamaları kullanarak deneyebilirsiniz. Yeni bir unsur,<fallback> öğesi, bileşenin başarısız olması durumunda kullanıcıya gönderilecek bir hata dizesini belirtmek için kullanılabilir.
The <jsp:element> Action
The <jsp:attribute> Action
The <jsp:body> Action
<jsp:element>, <jsp:attribute> ve <jsp:body>eylemler, XML öğelerini dinamik olarak tanımlamak için kullanılır. Sözcük dinamik olarak önemlidir, çünkü XML öğelerinin statik olarak derleme zamanında değil istek zamanında üretilebileceği anlamına gelir.
Aşağıda, XML öğelerini dinamik olarak tanımlamak için basit bir örnek verilmiştir -
<%@page language = "java" contentType = "text/html"%>
<html xmlns = "http://www.w3c.org/1999/xhtml"
xmlns:jsp = "http://java.sun.com/JSP/Page">
<head><title>Generate XML Element</title></head>
<body>
<jsp:element name = "xmlElement">
<jsp:attribute name = "xmlElementAttr">
Value for the attribute
</jsp:attribute>
<jsp:body>
Body for XML element
</jsp:body>
</jsp:element>
</body>
</html>
Bu, çalışma zamanında aşağıdaki HTML kodunu üretir -
<html xmlns = "http://www.w3c.org/1999/xhtml" xmlns:jsp = "http://java.sun.com/JSP/Page">
<head><title>Generate XML Element</title></head>
<body>
<xmlElement xmlElementAttr = "Value for the attribute">
Body for XML element
</xmlElement>
</body>
</html>
<Jsp: text> Eylem
<jsp:text>eylem şablon metnini JSP sayfalarına ve belgelerine yazmak için kullanılabilir. Bu eylem için basit sözdizimi aşağıdadır -
<jsp:text>Template data</jsp:text>
Şablonun gövdesi başka öğeler içeremez; yalnızca metin ve EL ifadeleri içerebilir (Not - EL ifadeleri sonraki bölümde açıklanmıştır). XML dosyalarında şu ifadeleri kullanamayacağınızı unutmayın:${whatever > 0}, çünkü büyüktür işaretleri yasa dışıdır. Bunun yerine,gt gibi form ${whatever gt 0} veya bir alternatif, değeri bir CDATA Bölüm.
<jsp:text><![CDATA[<br>]]></jsp:text>
Bir eklemeniz gerekiyorsa DOCTYPE beyanname, örneğin XHTML, ayrıca kullanmalısınız <jsp:text> aşağıdaki gibi eleman -
<jsp:text><![CDATA[<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"DTD/xhtml1-strict.dtd">]]></jsp:text>
<head><title>jsp:text action</title></head>
<body>
<books><book><jsp:text>
Welcome to JSP Programming
</jsp:text></book></books>
</body>
</html>
Yukarıdaki örneği birlikte ve olmadan deneyin <jsp:text> aksiyon.