JSP - Hızlı Kılavuz

JavaServer Pages nedir?

JavaServer Pages (JSP), dinamik içeriği destekleyen Web sayfaları geliştirmek için kullanılan bir teknolojidir. Bu, geliştiricilerin çoğu <% ile başlayan ve%> ile biten özel JSP etiketlerini kullanarak HTML sayfalarına java kodu eklemelerine yardımcı olur.

JavaServer Pages bileşeni, bir Java web uygulaması için kullanıcı arabirimi rolünü yerine getirmek üzere tasarlanmış bir Java sunucu uygulaması türüdür. Web geliştiricileri, JSP'leri HTML veya XHTML kodunu, XML öğelerini ve gömülü JSP eylemlerini ve komutlarını birleştiren metin dosyaları olarak yazar.

JSP'yi kullanarak, Web sayfası formları aracılığıyla kullanıcılardan girdi toplayabilir, bir veritabanından veya başka bir kaynaktan gelen kayıtları sunabilir ve dinamik olarak Web sayfaları oluşturabilirsiniz.

JSP etiketleri, bir veri tabanından bilgi almak veya kullanıcı tercihlerini kaydetmek, JavaBeans bileşenlerine erişmek, sayfalar arasında kontrolü aktarmak ve istekler, sayfalar vb. Arasında bilgi paylaşmak gibi çeşitli amaçlar için kullanılabilir.

Neden JSP Kullanılır?

JavaServer Sayfaları genellikle, Common Gateway Interface (CGI). Ancak JSP, CGI ile karşılaştırıldığında birçok avantaj sunar.

  • Performans önemli ölçüde daha iyidir çünkü JSP, Dinamik Öğelerin ayrı CGI dosyalarına sahip olmak yerine HTML Sayfalarının kendisine gömülmesine izin verir.

  • JSP, sunucunun bir yorumlayıcı ve sayfa her istendiğinde hedef betiği yüklemesini gerektiren CGI / Perl'den farklı olarak sunucu tarafından işlenmeden önce her zaman derlenir.

  • JavaServer Pages, Java Servlets API'sinin üzerine inşa edilmiştir; bu nedenle, Servlet'ler gibi, JSP de dahil olmak üzere tüm güçlü Enterprise Java API'lerine erişebilir. JDBC, JNDI, EJB, JAXP, vb.

  • JSP sayfaları, Java servlet şablon motorları tarafından desteklenen model olan iş mantığını işleyen sunucu uygulamalarıyla birlikte kullanılabilir.

Son olarak, JSP, kurumsal sınıf uygulamalar için eksiksiz bir platform olan Java EE'nin ayrılmaz bir parçasıdır. Bu, JSP'nin en basit uygulamalardan en karmaşık ve zorlu uygulamalara kadar bir rol oynayabileceği anlamına gelir.

JSP'nin Avantajları

Aşağıdaki tablo, JSP kullanmanın diğer teknolojilere göre diğer avantajlarını listelemektedir -

Active Server Pages (ASP) ile karşılaştırıldığında

JSP'nin avantajları iki yönlüdür. İlk olarak, dinamik kısım Visual Basic veya MS'e özgü başka bir dilde değil Java ile yazılmıştır, bu nedenle daha güçlü ve kullanımı daha kolaydır. İkincisi, diğer işletim sistemlerine ve Microsoft dışı Web sunucularına taşınabilir.

Pure Servletlere kıyasla

Düzenli HTML yazmak (ve değiştirmek!), HTML'yi oluşturan çok sayıda println deyimine sahip olmaktan daha uygundur.

Sunucu Tarafı İçerenler (SSI) ile

SSI, form verilerini kullanan, veritabanı bağlantıları kuran ve benzerlerini kullanan "gerçek" programlar için değil, sadece basit eklemeler için tasarlanmıştır.

JavaScript ile

JavaScript, istemcide dinamik olarak HTML oluşturabilir, ancak veritabanı erişimi ve görüntü işleme gibi karmaşık görevleri gerçekleştirmek için web sunucusuyla neredeyse hiç etkileşime giremez.

Statik HTML'ye kıyasla

Elbette normal HTML dinamik bilgi içeremez.

Sırada ne var?

Ortamınızı JSP ile başlayacak şekilde ayarlamak için sizi adım adım yönlendiririm. JSP'yi öğrenmeye devam etmek için Java Programlama konusunda iyi uygulamalı olduğunuzu varsayıyorum.

Java Programlama Dilinden haberdar değilseniz, Java Programlamayı anlamak için Java Eğitimimizi incelemenizi tavsiye ederiz .

Geliştirme ortamı, JSP programlarınızı geliştireceğiniz, test edeceğiniz ve sonunda çalıştıracağınız yerdir.

Bu eğitim, aşağıdaki adımları içeren JSP geliştirme ortamınızı kurmanız için size rehberlik edecektir -

Java Geliştirme Kitini Kurma

Bu adım, Java Yazılım Geliştirme Kiti'nin (SDK) bir uygulamasının indirilmesini ve PATH ortam değişkeninin uygun şekilde ayarlanmasını içerir.

SDK'yı Oracle'ın Java sitesinden indirebilirsiniz - Java SE İndirmeleri .

Java uygulamanızı indirdikten sonra, kurulumu kurmak ve yapılandırmak için verilen talimatları izleyin. SonundaPATH and JAVA_HOME içeren dizine başvurmak için ortam değişkenleri java ve javac, tipik java_install_dir/bin ve java_install_dir sırasıyla.

Windows çalıştırıyorsanız ve SDK'yı C:\jdk1.5.0_20, aşağıdaki satırı eklemeniz gerekir C:\autoexec.bat dosya.

set PATH = C:\jdk1.5.0_20\bin;%PATH%
set JAVA_HOME = C:\jdk1.5.0_20

Alternatif olarak, Windows NT/2000/XPayrıca sağ tıklayabilirsiniz My Computer, seçin Properties, sonra Advanced, bunu takiben Environment Variables. Ardından, PATH değerini güncellersiniz ve OK düğmesine basarsınız.

Unix'te (Solaris, Linux, vb.), SDK, /usr/local/jdk1.5.0_20 ve C kabuğunu kullanırsanız, aşağıdakileri .cshrc dosya.

setenv PATH /usr/local/jdk1.5.0_20/bin:$PATH
setenv JAVA_HOME /usr/local/jdk1.5.0_20

Alternatif olarak, bir Integrated Development Environment (IDE) sevmek Borland JBuilder, Eclipse, IntelliJ IDEAveya Sun ONE Studio, IDE'nin Java'yı nereye yüklediğinizi bildiğini doğrulamak için basit bir program derleyin ve çalıştırın.

Web Sunucusunun Kurulması: Tomcat

JavaServer Pages ve Servlet geliştirmeyi destekleyen bir dizi Web Sunucusu piyasada mevcuttur. Bazı web sunucuları ücretsiz olarak indirilebilir ve Tomcat bunlardan biridir.

Apache Tomcat, JavaServer Pages ve Servlet teknolojilerinin açık kaynaklı bir yazılım uygulamasıdır ve JSP ve Servlet'leri test etmek için bağımsız bir sunucu görevi görebilir ve Apache Web Sunucusu ile entegre edilebilir. Makinenizde Tomcat'i kurmanın adımları şunlardır -

  • Tomcat'in en son sürümünü şuradan indirin: https://tomcat.apache.org/.

  • Kurulumu indirdikten sonra, ikili dağıtımı uygun bir konuma açın. Örneğin,C:\apache-tomcat-5.5.29 on windows, or /usr/local/apache-tomcat-5.5.29 Linux / Unix üzerinde ve oluşturun CATALINA_HOME bu konumlara işaret eden ortam değişkeni.

Tomcat, Windows makinesinde aşağıdaki komutlar uygulanarak başlatılabilir -

%CATALINA_HOME%\bin\startup.bat
 
or
 
C:\apache-tomcat-5.5.29\bin\startup.bat

Tomcat, Unix (Solaris, Linux, vb.) Makinesinde aşağıdaki komutlar çalıştırılarak başlatılabilir -

$CATALINA_HOME/bin/startup.sh
 
or
 
/usr/local/apache-tomcat-5.5.29/bin/startup.sh

Başarılı bir başlangıçtan sonra, Tomcat'in içerdiği varsayılan web uygulamaları şu adrese ziyaret edilerek kullanılabilir olacaktır: http://localhost:8080/.

Yürütme üzerine, aşağıdaki çıktıyı alacaksınız -

Tomcat'in yapılandırılması ve çalıştırılması hakkında daha fazla bilgi burada bulunan belgelerde ve Tomcat web sitesinde bulunabilir - https://tomcat.apache.org/.

Tomcat, Windows makinesinde aşağıdaki komutlar çalıştırılarak durdurulabilir -

%CATALINA_HOME%\bin\shutdown
or

C:\apache-tomcat-5.5.29\bin\shutdown

Tomcat, Unix (Solaris, Linux, vb.) Makinesinde aşağıdaki komutlar çalıştırılarak durdurulabilir -

$CATALINA_HOME/bin/shutdown.sh

or

/usr/local/apache-tomcat-5.5.29/bin/shutdown.sh

CLASSPATH'ı kurma

Sunucu uygulamaları Java Platform, Standard Edition'ın bir parçası olmadığından, derleyiciye sunucu uygulaması sınıflarını tanımlamanız gerekir.

Windows çalıştırıyorsanız, aşağıdaki satırları sisteminize koymanız gerekir. C:\autoexec.bat dosya.

set CATALINA = C:\apache-tomcat-5.5.29
set CLASSPATH = %CATALINA%\common\lib\jsp-api.jar;%CLASSPATH%

Alternatif olarak, Windows NT/2000/XPayrıca sağ tıklayabilirsiniz My Computer, seçin Properties, sonra Advanced, sonra Environment Variables. Daha sonra CLASSPATH değerini güncellersiniz ve OK düğmesine basarsınız.

Unix'te (Solaris, Linux, vb.), C kabuğunu kullanıyorsanız, aşağıdaki satırları .cshrc dosya.

setenv CATALINA = /usr/local/apache-tomcat-5.5.29
setenv CLASSPATH $CATALINA/common/lib/jsp-api.jar:$CLASSPATH

NOTE - Geliştirme dizininizin C:\JSPDev (Windows) veya /usr/JSPDev (Unix), daha sonra bu dizinleri CLASSPATH'a da eklemeniz gerekir.

Web sunucusunun bir JSP motoruna, yani JSP sayfalarını işlemek için bir konteynere ihtiyacı vardır. JSP kapsayıcısı, JSP sayfalarına yönelik isteklerin yakalanmasından sorumludur. Bu eğitici, JSP sayfalarının geliştirilmesini desteklemek için yerleşik JSP kapsayıcısına sahip Apache'yi kullanır.

Bir JSP konteyneri, bir JSP'nin ihtiyaç duyduğu çalışma zamanı ortamını ve diğer hizmetleri sağlamak için Web sunucusuyla birlikte çalışır. JSP'lerin parçası olan özel unsurların nasıl anlaşılacağını bilir.

Aşağıdaki diyagram, JSP kapsayıcısının ve JSP dosyalarının bir Web uygulamasındaki konumunu göstermektedir.

JSP İşleme

Aşağıdaki adımlar, web sunucusunun JSP kullanarak Web sayfasını nasıl oluşturduğunu açıklar -

  • Normal bir sayfada olduğu gibi, tarayıcınız web sunucusuna bir HTTP isteği gönderir.

  • Web sunucusu, HTTP isteğinin bir JSP sayfası için olduğunu tanır ve bunu bir JSP motoruna iletir. Bu, ile biten URL veya JSP sayfası kullanılarak yapılır..jsp onun yerine .html.

  • JSP motoru, JSP sayfasını diskten yükler ve bir sunucu uygulaması içeriğine dönüştürür. Bu dönüştürme, tüm şablon metninin println () ifadelerine dönüştürüldüğü ve tüm JSP öğelerinin Java koduna dönüştürüldüğü çok basittir. Bu kod, sayfanın karşılık gelen dinamik davranışını uygular.

  • JSP motoru, sunucu uygulamasını çalıştırılabilir bir sınıfta derler ve orijinal isteği bir sunucu uygulaması motoruna iletir.

  • Web sunucusunun sunucu uygulaması motoru olarak adlandırılan bir bölümü, Servlet sınıfını yükler ve çalıştırır. Yürütme sırasında, sunucu uygulaması HTML biçiminde bir çıktı üretir. Çıktı, sunucu uygulaması motoru tarafından bir HTTP yanıtı içinde web sunucusuna iletilir.

  • Web sunucusu, HTTP yanıtını statik HTML içeriği açısından tarayıcınıza iletir.

  • Son olarak, web tarayıcısı dinamik olarak oluşturulmuş HTML sayfasını HTTP yanıtının içinde aynen statik bir sayfaymış gibi işler.

Yukarıda belirtilen tüm adımlar aşağıdaki diyagramda görülebilir -

Tipik olarak, JSP motoru, bir JSP dosyası için bir sunucu uygulamasının zaten var olup olmadığını ve JSP'deki değişiklik tarihinin sunucu uygulamasından daha eski olup olmadığını kontrol eder. JSP, oluşturulan sunucu uygulamasından daha eskiyse, JSP konteyner, JSP'nin değişmediğini ve üretilen sunucu uygulamasının hala JSP'nin içeriğiyle eşleştiğini varsayar. Bu, işlemi diğer betik dillerinden (PHP gibi) daha verimli ve dolayısıyla daha hızlı hale getirir.

Yani bir bakıma, bir JSP sayfası, Java programlama sihirbazı olmak zorunda kalmadan bir sunucu uygulaması yazmanın başka bir yoludur. Çeviri aşaması dışında, bir JSP sayfası tam olarak normal bir sunucu uygulaması gibi işlenir.

Bu bölümde JSP'nin yaşam döngüsünü tartışacağız. JSP'nin düşük seviyeli işlevselliğini anlamanın anahtarı, takip ettikleri basit yaşam döngüsünü anlamaktır.

Bir JSP yaşam döngüsü, yaratılışından yıkıma kadar geçen süreç olarak tanımlanır. Bu, bir JSP'yi sunucu uygulamasında derlemek için gereken ek bir adımla birlikte bir sunucu uygulaması yaşam döngüsüne benzer.

JSP Tarafından İzlenen Yollar

Aşağıdakiler, JSP tarafından izlenen yollardır -

  • Compilation
  • Initialization
  • Execution
  • Cleanup

Bir JSP yaşam döngüsünün dört ana aşaması, Servlet Yaşam Döngüsüne çok benzer. Dört aşama aşağıda açıklanmıştır -

JSP Derlemesi

Bir tarayıcı bir JSP istediğinde, JSP motoru önce sayfayı derlemesi gerekip gerekmediğini kontrol eder. Sayfa hiç derlenmemişse veya son derlenmesinden sonra JSP değiştirilmişse, JSP motoru sayfayı derler.

Derleme süreci üç adımdan oluşur -

  • JSP'nin ayrıştırılması.
  • JSP'yi sunucu uygulamasına dönüştürme.
  • Sunucu uygulamacığı derleniyor.

JSP Başlatma

Bir konteyner bir JSP yüklediğinde, jspInit()herhangi bir talebi karşılamadan önce yöntem. JSP'ye özgü başlatma yapmanız gerekiyorsa,jspInit() yöntem -

public void jspInit(){
   // Initialization code...
}

Genellikle, başlatma işlemi yalnızca bir kez gerçekleştirilir ve sunucu uygulaması başlatma yönteminde olduğu gibi, genellikle veritabanı bağlantılarını başlatır, dosyaları açar ve jspInit yönteminde arama tabloları oluşturursunuz.

JSP Yürütme

JSP yaşam döngüsünün bu aşaması, JSP yok edilene kadar isteklerle olan tüm etkileşimleri temsil eder.

Bir tarayıcı bir JSP istediğinde ve sayfa yüklendiğinde ve başlatıldığında, JSP motoru _jspService() JSP'deki yöntem.

_JspService () yöntemi bir HttpServletRequest ve bir HttpServletResponse aşağıdaki gibi parametreleri -

void _jspService(HttpServletRequest request, HttpServletResponse response) {
   // Service handling code...
}

_jspService()bir JSP yöntemi istek üzerine çağrılır. Bu, söz konusu istek için yanıt oluşturmaktan sorumludur ve bu yöntem, aynı zamanda, HTTP yöntemlerinin yedisine de yanıt oluşturmaktan sorumludur, örn.GET, POST, DELETE, vb.

JSP Temizleme

JSP yaşam döngüsünün imha aşaması, bir JSP'nin bir konteyner tarafından kullanımdan kaldırıldığı zamanı temsil eder.

jspDestroy()yöntem, sunucu uygulamaları için yok etme yönteminin JSP eşdeğeridir. Veritabanı bağlantılarını serbest bırakmak veya açık dosyaları kapatmak gibi herhangi bir temizleme işlemi yapmanız gerektiğinde jspDestroy'u geçersiz kılın.

JspDestroy () yöntemi şu biçime sahiptir -

public void jspDestroy() {
   // Your cleanup code goes here.
}

Bu bölümde, JSP'de Sözdizimi tartışacağız. JSP geliştirme ile ilgili basit sözdiziminin (yani unsurların) temel kullanımını anlayacağız.

JSP'nin Unsurları

JSP'nin unsurları aşağıda açıklanmıştır -

Scriptlet

Bir betik, sayfa betikleme dilinde geçerli olan herhangi bir sayıda JAVA dil ifadesi, değişken veya yöntem bildirimi veya ifade içerebilir.

Scriptlet'in sözdizimi aşağıdadır -

<% code fragment %>

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:scriptlet>
   code fragment
</jsp:scriptlet>

Yazdığınız herhangi bir metin, HTML etiketi veya JSP öğesi komut dosyasının dışında olmalıdır. JSP için basit ve ilk örnek aşağıdadır -

<html>
   <head><title>Hello World</title></head>
   
   <body>
      Hello World!<br/>
      <%
         out.println("Your IP address is " + request.getRemoteAddr());
      %>
   </body>
</html>

NOTE - Apache Tomcat'in C: \ apache-tomcat-7.0.2'de kurulu olduğunu ve ortamınızın ortam kurulum öğreticisine göre ayarlandığını varsayarsak.

Yukarıdaki kodu JSP dosyasında saklayalım hello.jsp ve bu dosyayı koy C:\apache-tomcat7.0.2\webapps\ROOTdizin. Aynı URL'yi kullanarak göz atınhttp://localhost:8080/hello.jsp. Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

JSP Beyanları

Bir bildirim, daha sonra JSP dosyasında Java kodunda kullanabileceğiniz bir veya daha fazla değişken veya yöntemi bildirir. Değişkeni veya yöntemi JSP dosyasında kullanmadan önce bildirmelisiniz.

JSP Bildirimleri için sözdizimi aşağıdadır -

<%! declaration; [ declaration; ]+ ... %>

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:declaration>
   code fragment
</jsp:declaration>

Aşağıda JSP Beyanları için bir örnek verilmiştir -

<%! int i = 0; %> 
<%! int a, b, c; %> 
<%! Circle a = new Circle(2.0); %>

JSP İfadesi

Bir JSP ifade öğesi, değerlendirilen, bir Dize'ye dönüştürülen ve ifadenin JSP dosyasında göründüğü yere eklenen bir komut dosyası dili ifadesi içerir.

İfadenin değeri Dizeye dönüştürüldüğünden, bir JSP dosyasında HTML ile etiketlenmiş olsun ya da olmasın bir metin satırı içinde bir ifade kullanabilirsiniz.

İfade öğesi, Java Dil Belirtimi'ne göre geçerli olan herhangi bir ifade içerebilir, ancak bir ifadeyi sonlandırmak için noktalı virgül kullanamazsınız.

JSP İfadesinin sözdizimi aşağıdadır -

<%= expression %>

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:expression>
   expression
</jsp:expression>

Aşağıdaki örnek bir JSP İfadesini göstermektedir -

<html> 
   <head><title>A Comment Test</title></head> 
   
   <body>
      <p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

Today's date: 11-Sep-2010 21:24:25

JSP Yorumları

JSP yorumu, JSP konteynerinin göz ardı etmesi gereken metin veya ifadeleri işaretler. Bir JSP yorumu, JSP sayfanızın bir parçası olan gizlemek veya "yorum yapmak" istediğinizde kullanışlıdır.

JSP yorumlarının sözdizimi aşağıdadır -

<%-- This is JSP comment --%>

Aşağıdaki örnek JSP Yorumlarını göstermektedir -

<html> 
   <head><title>A Comment Test</title></head> 
   
   <body> 
      <h2>A Test of Comments</h2> 
      <%-- This comment will not be visible in the page source --%> 
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

A Test of Comments

Aksi takdirde özel olarak ele alınacak yorumlar veya karakterler eklemek için çeşitli durumlarda kullanabileceğiniz az sayıda özel yapı vardır. İşte özet -

S.No. Sözdizimi ve Amaç
1

<%-- comment --%>

Bir JSP yorumu. JSP motoru tarafından göz ardı edildi.

2

<!-- comment -->

Bir HTML yorumu. Tarayıcı tarafından yok sayıldı.

3

<\%

Statik <% değişmez değeri temsil eder.

4

%\>

Statik%> değişmez değerini temsil eder.

5

\'

Tek tırnak kullanan bir öznitelikte tek bir alıntı.

6

\"

Çift tırnak kullanan bir öznitelikte çift tırnak.

JSP Direktifleri

Bir JSP yönergesi, sunucu uygulaması sınıfının genel yapısını etkiler. Genellikle şu biçime sahiptir -

<%@ directive attribute="value" %>

Üç tür yönerge etiketi vardır -

S.No. Yönerge ve Açıklama
1

<%@ page ... %>

Komut dosyası dili, hata sayfası ve arabelleğe alma gereksinimleri gibi sayfaya bağlı öznitelikleri tanımlar.

2

<%@ include ... %>

Çeviri aşamasında bir dosya içerir.

3

<%@ taglib ... %>

Sayfada kullanılan özel eylemleri içeren bir etiket kitaplığı bildirir

JSP direktifini ayrı bir bölümde açıklayacağız JSP - Direktifler

JSP Eylemleri

JSP eylemleri kullanır constructsSunucu uygulaması motorunun davranışını kontrol etmek için XML sözdiziminde. 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.

JSP eylemlerini ayrı bir bölümde açıklayacağız JSP - Eylemler

JSP Örtülü Nesneler

JSP, örtük nesneler olarak da adlandırılan otomatik olarak tanımlanmış dokuz değişkeni destekler. Bu değişkenler -

S.No. Nesne ve Açıklama
1

request

Bu HttpServletRequest istekle ilişkili nesne.

2

response

Bu HttpServletResponse müşteriye verilen yanıtla ilişkili nesne.

3

out

Bu PrintWriter istemciye çıktı göndermek için kullanılan nesne.

4

session

Bu HttpSession istekle ilişkili nesne.

5

application

Bu ServletContext uygulama bağlamıyla ilişkili nesne.

6

config

Bu ServletConfig sayfayla ilişkili nesne.

7

pageContext

Bu, daha yüksek performans gibi sunucuya özgü özelliklerin kullanımını kapsüller JspWriters.

8

page

Bu sadece eşanlamlıdır thisve çevrilen sunucu uygulaması sınıfı tarafından tanımlanan yöntemleri çağırmak için kullanılır.

9

Exception

Exception nesnesi, istisna verilerine belirlenen JSP tarafından erişilmesine izin verir.

JSP Örtük Nesneleri ayrı bir bölümde açıklayacağız JSP - Örtük Nesneler .

Kontrol Akışı İfadeleri

Karar verme ifadeleri, döngüler vb. Dahil olmak üzere Java'nın tüm API'lerini ve yapı taşlarını JSP programlamanızda kullanabilirsiniz.

Karar Verme Beyanları

if...else blok sıradan bir Scriptlet gibi başlar, ancak Scriptlet her satırda Scriptlet etiketleri arasına HTML metni dahil edilerek kapatılır.

<%! int day = 3; %> 
<html> 
   <head><title>IF...ELSE Example</title></head> 
   
   <body>
      <% if (day == 1 || day == 7) { %>
         <p> Today is weekend</p>
      <% } else { %>
         <p> Today is not weekend</p>
      <% } %>
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

Today is not weekend

Şimdi şuna bak switch...case kullanılarak biraz farklı yazılan blok out.println() ve Scriptletas'ın içinde -

<%! int day = 3; %> 
<html> 
   <head><title>SWITCH...CASE Example</title></head> 
   
   <body>
      <% 
         switch(day) {
            case 0:
               out.println("It\'s Sunday.");
               break;
            case 1:
               out.println("It\'s Monday.");
               break;
            case 2:
               out.println("It\'s Tuesday.");
               break;
            case 3:
               out.println("It\'s Wednesday.");
               break;
            case 4:
               out.println("It\'s Thursday.");
               break;
            case 5:
               out.println("It\'s Friday.");
               break;
            default:
               out.println("It's Saturday.");
         }
      %>
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

It's Wednesday.

Döngü İfadeleri

Java'da ayrıca üç temel döngü bloğu türü de kullanabilirsiniz: for, while, and do…while JSP programlamanızdaki bloklar.

Aşağıdakilere bakalım for döngü örneği -

<%! int fontSize; %> 
<html> 
   <head><title>FOR LOOP Example</title></head> 
   
   <body>
      <%for ( fontSize = 1; fontSize <= 3; fontSize++){ %>
         <font color = "green" size = "<%= fontSize %>">
            JSP Tutorial
      </font><br />
      <%}%>
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

JSP Tutorial 
JSP Tutorial
JSP Tutorial

Yukarıdaki örnek kullanılarak yazılabilir while aşağıdaki gibi döngü -

<%! int fontSize; %> 
<html> 
   <head><title>WHILE LOOP Example</title></head> 
   
   <body>
      <%while ( fontSize <= 3){ %>
         <font color = "green" size = "<%= fontSize %>">
            JSP Tutorial
         </font><br />
         <%fontSize++;%>
      <%}%>
   </body> 
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

JSP Tutorial 

 JSP Tutorial 

 JSP Tutorial

JSP Operatörleri

JSP, Java tarafından desteklenen tüm mantıksal ve aritmetik operatörleri destekler. Aşağıdaki tabloda, en yüksek önceliğe sahip tüm operatörler tablonun en üstünde, en düşük olanlar en altta görünür.

Bir ifade içinde, daha yüksek öncelikli operatörler ilk olarak değerlendirilecektir.

Kategori Şebeke İlişkisellik
Postfix () []. (nokta operatörü) Soldan sağa
Tekli ++ - -! ~ Sağdan sola
Çarpımsal * /% Soldan sağa
Katkı + - Soldan sağa
Vardiya >> >>> << Soldan sağa
İlişkisel >> = <<= Soldan sağa
Eşitlik ==! = Soldan sağa
Bitsel AND & Soldan sağa
Bitsel ÖZELVEYA ^ Soldan sağa
Bit tabanlı VEYA | Soldan sağa
Mantıksal AND && Soldan sağa
Mantıksal VEYA || Soldan sağa
Koşullu ?: Sağdan sola
Görev = + = - = * = / =% = >> = << = & = ^ = | = Sağdan sola
Virgül , Soldan sağa

JSP Edebiyatları

JSP ifade dili aşağıdaki değişmez değerleri tanımlar -

  • Boolean - doğru ve yanlış

  • Integer - Java'da olduğu gibi

  • Floating point - Java'da olduğu gibi

  • String- tek ve çift tırnaklarla; "\" olarak öncelenir, "\" olarak öncelenir ve \ \\ olarak öncelenir.

  • Null - boş

Bu bölümde, JSP'deki Direktifleri tartışacağız. Bu direktifler, konteynere JSP işlemenin belirli yönlerinin nasıl ele alınacağını anlatan talimatlar ve talimatlar sağlar.

Bir JSP yönergesi, sunucu uygulaması sınıfının genel yapısını etkiler. Genellikle şu biçime sahiptir -

<%@ directive attribute = "value" %>

Yönergeler, anahtar-değer çiftleri olarak listeleyebileceğiniz ve virgülle ayrılmış bir dizi özniteliğe sahip olabilir.

@ Sembolü ile yönerge adı arasındaki ve son öznitelik ile kapanış%> arasındaki boşluklar isteğe bağlıdır.

Üç tür yönerge etiketi vardır -

S.No. Yönerge ve Açıklama
1

<%@ page ... %>

Komut dosyası dili, hata sayfası ve arabelleğe alma gereksinimleri gibi sayfaya bağlı öznitelikleri tanımlar.

2

<%@ include ... %>

Çeviri aşamasında bir dosya içerir.

3

<%@ taglib ... %>

Sayfada kullanılan özel eylemleri içeren bir etiket kitaplığı bildirir

JSP - Sayfa Direktifi

pagedirektifi konteynere talimatlar sağlamak için kullanılır. Bu talimatlar mevcut JSP sayfasıyla ilgilidir. Sayfa yönergelerini JSP sayfanızın herhangi bir yerinde kodlayabilirsiniz. Kural olarak, sayfa yönergeleri JSP sayfasının en üstünde kodlanmıştır.

Sayfa yönergesinin temel sözdizimi aşağıdadır -

<%@ page attribute = "value" %>

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:directive.page attribute = "value" />

Öznitellikler

Aşağıdaki tablo, sayfa yönergesi ile ilişkili öznitelikleri listeler -

S.No. Nitelik ve Amaç
1

buffer

Çıkış akışı için arabelleğe alma modelini belirtir.

2

autoFlush

Sunucu uygulamacığı çıktı arabelleğinin davranışını kontrol eder.

3

contentType

Karakter kodlama şemasını tanımlar.

4

errorPage

Java'nın denetlenmemiş çalışma zamanı istisnalarını raporlayan başka bir JSP'nin URL'sini tanımlar.

5

isErrorPage

Bu JSP sayfasının başka bir JSP sayfasının errorPage özniteliği tarafından belirtilen bir URL olup olmadığını gösterir.

6

extends

Oluşturulan sunucu uygulamasının genişletmesi gereken bir üst sınıfı belirtir.

7

import

Java içe aktarma ifadesinin Java sınıfları için yaptığı gibi, JSP'de kullanılacak paketlerin veya sınıfların bir listesini belirtir.

8

info

Sunucu uygulaması ile erişilebilen bir dizeyi tanımlar. getServletInfo() yöntem.

9

isThreadSafe

Oluşturulan sunucu uygulaması için iş parçacığı modelini tanımlar.

10

language

JSP sayfasında kullanılan programlama dilini tanımlar.

11

session

JSP sayfasının HTTP oturumlarına katılıp katılmayacağını belirtir

12

isELIgnored

JSP sayfasındaki EL ifadesinin göz ardı edilip edilmeyeceğini belirtir.

13

isScriptingEnabled

Komut dosyası öğelerinin kullanımına izin verilip verilmediğini belirler.

Sayfa Direktifi'nde yukarıdaki tüm özelliklerle ilgili daha fazla ayrıntı için kontrol edin .

Direktif dahil

includedirektifi, çeviri aşamasında bir dosya eklemek için kullanılır. Bu yönerge, konteynere çeviri aşamasında diğer harici dosyaların içeriğini mevcut JSP ile birleştirmesini söyler. Kodlayabilirsinizinclude JSP sayfanızın herhangi bir yerinde yönergeler.

Bu direktifin genel kullanım şekli aşağıdaki gibidir -

<%@ include file = "relative url" >

İnclude yönergesindeki dosya adı aslında göreli bir URL'dir. İlişkili yolu olmayan bir dosya adı belirtirseniz, JSP derleyicisi dosyanın JSP'nizle aynı dizinde olduğunu varsayar.

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:directive.include file = "relative url" />

Dahil etme direktifiyle ilgili daha fazla ayrıntı için Dahil Etme Direktifi'ne bakın .

Taglib Yönergesi

JavaServer Pages API, HTML veya XML etiketleri gibi görünen özel JSP etiketleri tanımlamanıza izin verir ve bir etiket kitaplığı, özel davranışı uygulayan bir dizi kullanıcı tanımlı etiketlerdir.

taglib yönergesi, JSP sayfanızın bir dizi özel etiket kullandığını, kitaplığın konumunu belirlediğini ve JSP sayfanızdaki özel etiketleri tanımlamak için araçlar sağladığını bildirir.

Taglib direktifi aşağıda verilen sözdizimini izler -

<%@ taglib uri="uri" prefix = "prefixOfTag" >

Burada uri öznitelik değeri, kabın anladığı bir konuma çözümlenir ve prefix özniteliği, kapsayıcıya hangi biçimlendirme bitlerinin özel eylemler olduğunu bildirir.

Yukarıdaki söz diziminin XML eşdeğerini aşağıdaki gibi yazabilirsiniz -

<jsp:directive.taglib uri = "uri" prefix = "prefixOfTag" />

Taglib direktifi ile ilgili daha fazla detay için Taglib Direktifi'ne bakın .

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 dahil edilmeden önce tamponunun temizlenip temizlenmediğini 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 bean 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 elemanı, 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 elemanı, 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 bunu çıktıya ekler.

GetProperty eyleminin her ikisi de gerekli olan yalnızca iki özelliği vardır. 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ı 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 eylemiyle 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> gerektiği gibi etiketler.

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.

Bu bölümde, JSP'deki Örtük Nesneleri tartışacağız. Bu Nesneler, JSP Konteynerinin her sayfada geliştiricilere sunduğu Java nesneleridir ve geliştirici, açıkça bildirilmeden bunları doğrudan çağırabilir. JSP Örtük Nesneleri de denirpre-defined variables.

Aşağıdaki tablo, JSP'nin desteklediği dokuz Örtük Nesneyi listeler -

S.No. Nesne ve Açıklama
1

request

Bu HttpServletRequest istekle ilişkili nesne.

2

response

Bu HttpServletResponse müşteriye verilen yanıtla ilişkili nesne.

3

out

Bu PrintWriter istemciye çıktı göndermek için kullanılan nesne.

4

session

Bu HttpSession istekle ilişkili nesne.

5

application

Bu ServletContext uygulama bağlamıyla ilişkili nesne.

6

config

Bu ServletConfig sayfayla ilişkili nesne.

7

pageContext

Bu, daha yüksek performans gibi sunucuya özgü özelliklerin kullanımını kapsüller JspWriters.

8

page

Bu sadece eşanlamlıdır thisve çevrilen sunucu uygulaması sınıfı tarafından tanımlanan yöntemleri çağırmak için kullanılır.

9

Exception

Exception nesnesi, istisna verilerine belirlenen JSP tarafından erişilmesine izin verir.

İstek Nesne

İstek nesnesi, bir javax.servlet.http.HttpServletRequestnesne. Bir istemci bir sayfa istediğinde, JSP motoru bu isteği temsil etmek için yeni bir nesne oluşturur.

İstek nesnesi, form verileri, tanımlama bilgileri, HTTP yöntemleri vb. Dahil olmak üzere HTTP başlık bilgilerini almak için yöntemler sağlar.

Sonraki bölümde, istek nesnesiyle ilişkili tüm yöntemleri ele alabiliriz - JSP - İstemci İsteği .

Yanıt Nesnesi

Yanıt nesnesi, bir javax.servlet.http.HttpServletResponsenesne. Sunucunun istek nesnesini oluşturması gibi, istemciye verilen yanıtı temsil edecek bir nesne de oluşturur.

Yanıt nesnesi ayrıca yeni HTTP üstbilgileri oluşturmayla ilgilenen arabirimleri de tanımlar. Bu nesne aracılığıyla JSP programcısı yeni tanımlama bilgileri veya tarih damgaları, HTTP durum kodları vb. Ekleyebilir.

Sonraki bölümde, yanıt nesnesiyle ilişkili tüm yöntemleri ele alacağız - JSP - Sunucu Yanıtı .

Dışarı Nesne

Dışarıdaki örtük nesne, bir javax.servlet.jsp.JspWriter nesne ve bir yanıtta içerik göndermek için kullanılır.

İlk JspWriter nesnesi, sayfanın arabelleğe alınıp alınmamasına bağlı olarak farklı şekilde başlatılır. Arabelleğe alma, kullanılarak kolayca kapatılabilir.buffered = 'false' sayfa yönergesinin özniteliği.

JspWriter nesnesi, aynı yöntemlerin çoğunu içerir. java.io.PrintWritersınıf. Ancak, JspWriter arabelleğe alma ile başa çıkmak için tasarlanmış bazı ek yöntemlere sahiptir. PrintWriter nesnesinin aksine JspWriter,IOExceptions.

Aşağıdaki tablo yazmak için kullanacağımız önemli yöntemleri listeler. boolean char, int, double, object, String, vb.

S.No. Yöntem ve Açıklama
1

out.print(dataType dt)

Bir veri türü değeri yazdırın

2

out.println(dataType dt)

Bir veri türü değeri yazdırın ve ardından satırı yeni satır karakteriyle sonlandırın.

3

out.flush()

Akışı yıkayın.

Oturum Nesnesi

Oturum nesnesi bir örneğidir javax.servlet.http.HttpSession ve Java Servletleri altında oturum nesnelerinin tam olarak aynı şekilde davranır.

Oturum nesnesi, istemci istekleri arasındaki istemci oturumunu izlemek için kullanılır. Sonraki bölümde oturum nesnesinin tam kullanımını ele alacağız - JSP - Oturum İzleme .

Uygulama Nesnesi

Uygulama nesnesi, ServletContext oluşturulan Servlet için nesne ve gerçekte bir javax.servlet.ServletContext nesne.

Bu nesne, tüm yaşam döngüsü boyunca JSP sayfasının bir temsilidir. Bu nesne, JSP sayfası başlatıldığında oluşturulur ve JSP sayfası tarafından kaldırıldığında kaldırılır.jspDestroy() yöntem.

Uygulamaya bir öznitelik ekleyerek, web uygulamanızı oluşturan tüm JSP dosyalarının ona erişiminin olmasını sağlayabilirsiniz.

JSP - Hits Counter bölümünde Uygulama Nesnesinin kullanımını kontrol edeceğiz .

Yapılandırma Nesnesi

Config nesnesi bir örneğidir javax.servlet.ServletConfig ve etrafındaki doğrudan bir paketleyicidir. ServletConfig oluşturulan sunucu uygulaması için nesne.

Bu nesne, JSP programcısının, yollar veya dosya konumları gibi Servlet veya JSP motoru başlatma parametrelerine erişmesine izin verir.

Aşağıdaki config yöntem, kullanabileceğiniz tek yöntemdir ve kullanımı önemsizdir -

config.getServletName();

Bu, sunucu uygulamacığı adını döndürür; bu, <servlet-name> içinde tanımlanan öğe WEB-INF\web.xml dosya.

PageContext Nesnesi

PageContext nesnesi, bir javax.servlet.jsp.PageContextnesne. PageContext nesnesi, JSP sayfasının tamamını temsil etmek için kullanılır.

Bu nesne, uygulama ayrıntılarının çoğundan kaçınırken sayfa hakkındaki bilgilere erişme aracı olarak tasarlanmıştır.

Bu nesne, her istek için istek ve yanıt nesnelerine başvuruları depolar. application, config, sessionve out nesneleri, bu nesnenin özelliklerine erişilerek türetilir.

PageContext nesnesi ayrıca arabelleğe alma bilgileri, errorPageURL ve sayfa kapsamı dahil olmak üzere JSP sayfasına verilen yönergeler hakkında bilgi içerir.

PageContext sınıfı, aşağıdakiler dahil birkaç alanı tanımlar: PAGE_SCOPE, REQUEST_SCOPE, SESSION_SCOPE, ve APPLICATION_SCOPE, dört kapsamı tanımlayan. Ayrıca, yaklaşık yarısı yarısından miras alınan 40'tan fazla yöntemi destekler.javax.servlet.jsp.JspContext class.

Önemli yöntemlerden biri removeAttribute. Bu yöntem bir veya iki argümanı kabul eder. Örneğin,pageContext.removeAttribute ("attrName") özelliği tüm kapsamlardan kaldırırken, aşağıdaki kod onu yalnızca sayfa kapsamından kaldırır -

pageContext.removeAttribute("attrName", PAGE_SCOPE);

PageContext kullanımı JSP - Dosya Yükleme bölümünde kontrol edilebilir .

Sayfa Nesnesi

Bu nesne, sayfanın örneğine gerçek bir referanstır. Tüm JSP sayfasını temsil eden bir nesne olarak düşünülebilir.

Sayfa nesnesi, gerçekte doğrudan eşanlamlıdır. this nesne.

İstisna Nesnesi

İstisna nesnesi, önceki sayfadan atılan istisnayı içeren bir sarmalayıcıdır. Genellikle hata durumuna uygun bir yanıt oluşturmak için kullanılır.

Bu nesnenin tam kullanımını JSP - İstisna İşleme bölümünde ele alacağız .

Bu bölümde, JSP'de Müşteri İsteğini tartışacağız. Bir tarayıcı bir Web sayfası istediğinde, web sunucusuna birçok bilgi gönderir. Bu bilgi, HTTP isteğinin başlığının bir parçası olarak dolaştığı için bu bilgi doğrudan okunamaz. Bununla ilgili daha fazla bilgi için HTTP Protokolünü kontrol edebilirsiniz .

Aşağıdaki tablo, tarayıcıdan gelen önemli başlık bilgilerini listeler. Bu bilgiler sıklıkla web programlamada kullanılır -

S.No. Üstbilgi ve Açıklama
1

Accept

Bu başlık, MIMEtarayıcının veya diğer istemcilerin işleyebileceği türler. Değerleriimage/png veya image/jpeg en yaygın iki olasılıktır.

2

Accept-Charset

Bu başlık, tarayıcının bilgileri görüntülemek için kullanabileceği karakter kümelerini belirtir. Örneğin,ISO-8859-1.

3

Accept-Encoding

Bu başlık, tarayıcının nasıl işleyeceğini bildiği kodlama türlerini belirtir. Değerlerigzip veya compress en yaygın iki olasılıktır.

4

Accept-Language

Bu başlık, sunucu uygulamasının birden fazla dilde sonuç üretebilmesi durumunda istemcinin tercih ettiği dilleri belirtir. Örneğinen, en-us, ru, vb.

5

Authorization

Bu başlık, istemciler tarafından parola korumalı web sayfalarına erişirken kendilerini tanıtmak için kullanılır.

6

Connection

Bu başlık, istemcinin kalıcı HTTP bağlantılarını işleyip işlemediğini gösterir. Kalıcı bağlantılar, istemcinin veya diğer tarayıcının tek bir istekle birden çok dosyayı almasına izin verir. DeğeriKeep-Alive kalıcı bağlantıların kullanılması gerektiği anlamına gelir.

7

Content-Length

Bu başlık yalnızca şunlar için geçerlidir: POST POST verilerinin boyutunu bayt cinsinden ister ve verir.

8

Cookie

Bu başlık, çerezleri daha önce tarayıcıya gönderen sunuculara döndürür.

9

Host

Bu başlık, orijinal URL'de verildiği şekliyle ana bilgisayarı ve bağlantı noktasını belirtir.

10

If-Modified-Since

Bu başlık, müşterinin sayfayı yalnızca belirtilen tarihten sonra değiştirilmişse istediğini belirtir. Sunucu bir kod gönderir, bu da şu anlama gelir:Not Modified daha yeni bir sonuç yoksa başlık.

11

If-Unmodified-Since

Bu başlık şunun tersidir If-Modified-Since; yalnızca belgenin belirtilen tarihten daha eski olması durumunda işlemin başarılı olması gerektiğini belirtir.

12

Referer

Bu başlık, yönlendiren web sayfalarının URL'sini gösterir. Örneğin, Web Sayfası 1'deyseniz ve Web Sayfası 2'ye giden bir bağlantıyı tıklarsanız, tarayıcı Web Sayfası 2'yi istediğinde Web Sayfası 1'in URL'si Referer başlığına eklenir.

13

User-Agent

Bu başlık, istekte bulunan tarayıcıyı veya diğer istemciyi tanımlar ve farklı içeriği farklı tarayıcı türlerine döndürmek için kullanılabilir.

HttpServletRequest Nesnesi

İstek nesnesi, bir javax.servlet.http.HttpServletRequestnesne. Bir istemci bir sayfa istediğinde, JSP motoru bu isteği temsil etmek için yeni bir nesne oluşturur.

İstek nesnesi, HTTP başlık bilgilerini almak için yöntemler sağlar. form data, cookies, HTTP methods, vb.

Aşağıdaki tablo, JSP programınızda HTTP başlığını okumak için kullanılabilecek önemli yöntemleri listeler. Bu yöntemler, web sunucusuna istemci talebini temsil eden HttpServletRequest nesnesiyle kullanılabilir .

S.No. Yöntem ve Açıklama
1

Cookie[] getCookies()

İstemcinin bu istekle gönderdiği tüm Çerez nesnelerini içeren bir dizi döndürür.

2

Enumeration getAttributeNames()

Bu istek için kullanılabilen özniteliklerin adlarını içeren bir Numaralandırma döndürür.

3

Enumeration getHeaderNames()

Bu isteğin içerdiği tüm başlık adlarının bir listesini döndürür.

4

Enumeration getParameterNames()

Bu istekte bulunan parametrelerin adlarını içeren String nesnelerinin bir listesini döndürür.

5

HttpSession getSession()

Bu istekle ilişkili geçerli oturumu döndürür veya isteğin bir oturumu yoksa bir oturum oluşturur.

6

HttpSession getSession(boolean create)

Bu istekle ilişkili geçerli HttpSession'ı döndürür veya geçerli oturum yoksa ve create true ise, yeni bir oturum döndürür.

7

Locale getLocale()

Accept-Language başlığına bağlı olarak istemcinin içeriği kabul edeceği tercih edilen Yerel Ayarı döndürür.

8

Object getAttribute(String name)

Adlandırılmış özniteliğin değerini bir Nesne olarak döndürür veya verilen adın özniteliği yoksa null döndürür.

9

ServletInputStream getInputStream()

ServletInputStream kullanarak isteğin gövdesini ikili veri olarak alır.

10

String getAuthType()

Sunucu uygulamasını korumak için kullanılan kimlik doğrulama şemasının adını, örneğin "BASIC" veya "SSL" veya JSP korumalı değilse null döndürür.

11

String getCharacterEncoding()

Bu isteğin gövdesinde kullanılan karakter kodlamasının adını döndürür.

12

String getContentType()

İsteğin gövdesinin MIME türünü veya tür bilinmiyorsa boş değerini döndürür.

13

String getContextPath()

İstek URI'sinin, isteğin içeriğini gösteren kısmını döndürür.

14

String getHeader(String name)

Belirtilen istek başlığının değerini bir String olarak döndürür.

15

String getMethod()

GET, POST veya PUT gibi bu isteğin yapıldığı HTTP yönteminin adını döndürür.

16

String getParameter(String name)

Bir istek parametresinin değerini String olarak veya parametre mevcut değilse null olarak döndürür.

17

String getPathInfo()

İstemcinin bu istekte bulunduğunda gönderdiği URL ile ilişkili tüm ekstra yol bilgilerini döndürür.

18

String getProtocol()

İsteğin kullandığı protokolün adını ve sürümünü döndürür.

19

String getQueryString()

Yoldan sonra istek URL'sinde bulunan sorgu dizesini döndürür.

20

String getRemoteAddr()

İsteği gönderen istemcinin İnternet Protokolü (IP) adresini döndürür.

21

String getRemoteHost()

İsteği gönderen istemcinin tam nitelikli adını döndürür.

22

String getRemoteUser()

Kullanıcı kimliği doğrulanmışsa, bu istekte bulunan kullanıcının oturum açma bilgilerini döndürür veya kullanıcı kimliği doğrulanmamışsa boş değeri döndürür.

23

String getRequestURI()

Bu isteğin URL'sinin, protokol adından HTTP isteğinin ilk satırındaki sorgu dizesine kadar olan kısmını döndürür.

24

String getRequestedSessionId()

İstemci tarafından belirtilen oturum kimliğini döndürür.

25

String getServletPath()

Bu isteğin URL'sinin JSP'yi çağıran kısmını döndürür.

26

String[] getParameterValues(String name)

Verilen istek parametresinin sahip olduğu tüm değerleri içeren bir String nesneleri dizisi döndürür veya parametre yoksa null döndürür.

27

boolean isSecure()

Bu isteğin HTTPS gibi güvenli bir kanal kullanılarak yapılıp yapılmadığını belirten bir boole döndürür.

28

int getContentLength()

İstek gövdesinin bayt cinsinden uzunluğunu ve giriş akışı tarafından kullanılabilir hale getirilen uzunluğunu veya uzunluk bilinmiyorsa -1 değerini döndürür.

29

int getIntHeader(String name)

Belirtilen istek başlığının değerini bir int olarak döndürür.

30

int getServerPort()

Bu isteğin alındığı bağlantı noktası numarasını döndürür.

HTTP Üstbilgi İsteği Örneği

Kullanan örnek aşağıdadır getHeaderNames() yöntemi HttpServletRequestHTTP başlık bilgilerini okumak için. Bu yöntem, geçerli HTTP isteği ile ilişkili başlık bilgilerini içeren bir Numaralandırma döndürür.

Bir Numaralandırmaya sahip olduğumuzda, Numaralamayı standart bir şekilde azaltabiliriz. KullanacağızhasMoreElements() ne zaman duracağını belirleme yöntemi ve nextElement() her parametre adının adını alma yöntemi.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>HTTP Header Request Example</title>
   </head>

   <body>
      <center>
         <h2>HTTP Header Request Example</h2>
         
         <table width = "100%" border = "1" align = "center">
            <tr bgcolor = "#949494">
               <th>Header Name</th>
               <th>Header Value(s)</th>
            </tr>
            <%
               Enumeration headerNames = request.getHeaderNames();
               while(headerNames.hasMoreElements()) {
                  String paramName = (String)headerNames.nextElement();
                  out.print("<tr><td>" + paramName + "</td>\n");
                  String paramValue = request.getHeader(paramName);
                  out.println("<td> " + paramValue + "</td></tr>\n");
               }
            %>
         </table>
      </center>
   
   </body>
</html>

Şimdi yukarıdaki kodu yerine koyalım main.jsp ve erişmeye çalışın.

HTTP Üstbilgi İsteği Örneği

Üstbilgi Adı Üstbilgi Değerleri
kabul etmek * / *
kabul dili en-us
kullanıcı aracısı Mozilla / 4.0 (uyumlu; MSIE 7.0; Windows NT 5.1; Trident / 4.0; InfoPath.2; MS-RTC LM 8)
kodlamayı kabul et gzip, deflate
ev sahibi localhost: 8080
bağ Hayatta kal
önbellek denetimi önbelleksiz

Tüm yöntemler üzerinde benzer şekilde çalışmayı deneyebilirsiniz.

Bu bölümde, JSP'deki Sunucu Yanıtını tartışacağız. Bir Web sunucusu bir HTTP isteğine yanıt verdiğinde, yanıt tipik olarak bir durum satırı, bazı yanıt başlıkları, boş bir satır ve belgeden oluşur. Tipik bir yanıt şuna benzer -

HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
   (Blank Line)
<!doctype ...>

<html>
   <head>...</head>
   <body>
      ...
   </body>
</html>

Durum satırı HTTP versiyonundan oluşur (HTTP/1.1 in the example)bir durum kodu (200 in the example)ve durum koduna karşılık gelen çok kısa bir mesaj (OK in the example).

Aşağıda, web sunucusundan tarayıcıya geri dönen en kullanışlı HTTP 1.1 yanıt başlıklarının bir özeti verilmektedir. Bu başlıklar genellikle web programlamada kullanılır -

S.No. Üstbilgi ve Açıklama
1

Allow

Bu başlık, istek yöntemlerini belirtir (GET, POST, vb.) sunucunun desteklediği.

2

Cache-Control

Bu başlık, yanıt belgesinin güvenli bir şekilde önbelleğe alınabileceği koşulları belirtir. Değerlere sahip olabilirpublic, private veya no-cache vb. Genel, belgenin önbelleğe alınabilir olduğu anlamına gelir; Özel, belgenin tek bir kullanıcı için olduğu ve yalnızca özel (paylaşılmayan) önbelleklerde saklanabileceği ve önbelleksiz olmadığı anlamına gelir, belgenin asla önbelleğe alınmaması gerektiği anlamına gelir.

3

Connection

Bu başlık, tarayıcıya kalıcı HTTP bağlantılarının kullanılıp kullanılmayacağını bildirir. Değericlose tarayıcıya kalıcı HTTP bağlantılarını kullanmaması talimatını verir ve keep-alive kalıcı bağlantılar kullanmak anlamına gelir.

4

Content-Disposition

Bu başlık, tarayıcının kullanıcıdan yanıtı verilen adda bir dosyaya diske kaydetmesini istemesini istemenizi sağlar.

5

Content-Encoding

Bu başlık, sayfanın iletim sırasında kodlanma şeklini belirtir.

6

Content-Language

Bu başlık, belgenin yazıldığı dili belirtir. Örneğin,en, en-us, ru, vb.

7

Content-Length

Bu başlık, yanıttaki bayt sayısını gösterir. Bu bilgiler, yalnızca tarayıcı kalıcı (canlı tutma) HTTP bağlantısı kullanıyorsa gereklidir.

8

Content-Type

Bu başlık, MIME (Multipurpose Internet Mail Extension) yanıt belgesinin türü.

9

Expires

Bu başlık, içeriğin güncel olmadığı ve dolayısıyla artık önbelleğe alınmayacağı zamanı belirtir.

10

Last-Modified

Bu başlık, belgenin en son ne zaman değiştirildiğini gösterir. İstemci daha sonra belgeyi önbelleğe alabilir ve bir tarih belirleyebilir.If-Modified-Since sonraki isteklerde başlık isteyin.

11

Location

Bu başlık, 300'lerde bir durum kodu olan tüm yanıtlara dahil edilmelidir. Bu, tarayıcıya belge adresini bildirir. Tarayıcı bu konuma otomatik olarak yeniden bağlanır ve yeni belgeyi alır.

12

Refresh

Bu başlık, tarayıcının ne kadar sürede güncellenmiş bir sayfa isteyeceğini belirtir. Bir sayfanın yenilenmesi için geçmesi gereken süreyi saniye cinsinden belirtebilirsiniz.

13

Retry-After

Bu başlık, bir 503 (Service Unavailable) Müşteriye talebini ne kadar sürede tekrar edebileceğini bildirmek için yanıt.

14

Set-Cookie

Bu başlık, sayfayla ilişkilendirilmiş bir çerezi belirtir.

HttpServletResponse Nesnesi

Yanıt nesnesi, bir javax.servlet.http.HttpServletResponse object. Sunucunun istek nesnesini oluşturması gibi, istemciye verilen yanıtı temsil edecek bir nesne de oluşturur.

Yanıt nesnesi ayrıca yeni HTTP üstbilgileri oluşturmayla ilgilenen arabirimleri de tanımlar. Bu nesne aracılığıyla, JSP programcısı yeni çerezler veya tarih damgaları, HTTP durum kodları vb. Ekleyebilir.

Sunucu uygulaması programınızda HTTP yanıt başlığını ayarlamak için aşağıdaki yöntemler kullanılabilir. Bu yöntemler HttpServletResponse nesnesiyle kullanılabilir. Bu nesne, sunucu yanıtını temsil eder.

S.No. Yöntem ve Açıklama
1

String encodeRedirectURL(String url)

Belirtilen URL'yi kullanım için kodlar sendRedirect yöntem veya kodlama gerekli değilse, URL'yi değiştirmeden döndürür.

2

String encodeURL(String url)

Belirtilen URL'yi, içine oturum kimliğini ekleyerek kodlar veya kodlama gerekmiyorsa, URL'yi değiştirmeden döndürür.

3

boolean containsHeader(String name)

Adlandırılmış yanıt başlığının önceden ayarlanıp ayarlanmadığını gösteren bir boole döndürür.

4

boolean isCommitted()

Yanıtın işlenip işlenmediğini belirten bir mantıksal değer döndürür.

5

void addCookie(Cookie cookie)

Belirtilen çerezi yanıta ekler.

6

void addDateHeader(String name, long date)

Verilen ad ve tarih değeriyle bir yanıt başlığı ekler.

7

void addHeader(String name, String value)

Verilen ad ve değere sahip bir yanıt başlığı ekler.

8

void addIntHeader(String name, int value)

Verilen ada ve tamsayı değerine sahip bir yanıt başlığı ekler.

9

void flushBuffer()

Arabellekteki herhangi bir içeriği istemciye yazılmasına zorlar.

10

void reset()

Arabellekte bulunan tüm verileri, durum kodunu ve başlıkları temizler.

11

void resetBuffer()

Başlıkları veya durum kodunu temizlemeden yanıttaki temeldeki arabelleğin içeriğini temizler.

12

void sendError(int sc)

Belirtilen durum kodunu kullanarak ve arabelleği temizleyerek istemciye bir hata yanıtı gönderir.

13

void sendError(int sc, String msg)

Belirtilen durumu kullanarak istemciye bir hata yanıtı gönderir.

14

void sendRedirect(String location)

Belirtilen yönlendirme konumu URL'sini kullanarak istemciye geçici bir yeniden yönlendirme yanıtı gönderir.

15

void setBufferSize(int size)

Yanıtın gövdesi için tercih edilen arabellek boyutunu ayarlar.

16

void setCharacterEncoding(String charset)

İstemciye gönderilen yanıtın karakter kodlamasını (MIME karakter kümesi), örneğin UTF-8 olarak ayarlar.

17

void setContentLength(int len)

Yanıttaki içerik gövdesinin uzunluğunu ayarlar HTTP sunucu uygulamalarında; bu yöntem ayrıca HTTP Content-Length başlığını da ayarlar.

18

void setContentType(String type)

Yanıt henüz işlenmemişse, istemciye gönderilen yanıtın içerik türünü ayarlar.

19

void setDateHeader(String name, long date)

Verilen ad ve tarih değerine sahip bir yanıt başlığı ayarlar.

20

void setHeader(String name, String value)

Verilen ad ve değere sahip bir yanıt başlığı ayarlar.

21

void setIntHeader(String name, int value)

Verilen ada ve tamsayı değerine sahip bir yanıt başlığı ayarlar.

22

void setLocale(Locale loc)

Yanıt henüz işlenmemişse yanıtın yerel ayarını ayarlar.

23

void setStatus(int sc)

Bu yanıt için durum kodunu ayarlar.

HTTP Üstbilgi Yanıtı Örneği

Aşağıdaki örnek kullanacaktır setIntHeader() ayarlama yöntemi Refresh dijital bir saati simüle etmek için başlık -

<%@ page import = "java.io.*,java.util.*" %>

<html>
   
   <head>
      <title>Auto Refresh Header Example</title>
   </head>
   
   <body>
      <center>
         <h2>Auto Refresh Header Example</h2>
         <%
            // Set refresh, autoload time as 5 seconds
            response.setIntHeader("Refresh", 5);
            
            // Get current time
            Calendar calendar = new GregorianCalendar();
            
            String am_pm;
            int hour = calendar.get(Calendar.HOUR);
            int minute = calendar.get(Calendar.MINUTE);
            int second = calendar.get(Calendar.SECOND);
            
            if(calendar.get(Calendar.AM_PM) == 0) 
               am_pm = "AM";
            else
               am_pm = "PM";
               String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
               out.println("Current Time is: " + CT + "\n");
         %>
      </center>
   
   </body>
</html>

Şimdi yukarıdaki kodu yerleştirin main.jspve erişmeye çalışın. Bu, aşağıdaki gibi her 5 saniyede bir mevcut sistem zamanını gösterecektir. JSP'yi çalıştırın. Aşağıdaki çıktıyı alacaksınız: -

Auto Refresh Header Example

Current Time is: 9:44:50 PM

Diğer yöntemler üzerinde de benzer şekilde çalışmayı deneyebilirsiniz.

Bu bölümde, JSP'deki Http Durum Kodlarını tartışacağız. HTTP isteğinin ve HTTP yanıt mesajlarının biçimi benzerdir ve aşağıdaki yapıya sahip olacaktır -

  • Bir başlangıç ​​durum satırı + CRLF (Satır Başı + Satır Besleme yani Yeni Satır)

  • Sıfır veya daha fazla başlık satırı + CRLF

  • Boş bir satır yani. bir CRLF

  • Dosya, sorgu verileri veya sorgu çıktısı gibi isteğe bağlı bir mesaj gövdesi.

Örneğin, bir sunucu yanıt başlığı aşağıdaki gibi görünür -

HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
   (Blank Line)
<!doctype ...>

<html>
   <head>...</head>
   
   <body>
      ...
   </body>
</html>

Durum satırı şunlardan oluşur: HTTP version (HTTP/1.1 in the example), bir durum kodu (örnekte 200) ve durum koduna karşılık gelen çok kısa bir mesaj (OK in the example).

Aşağıdaki tablo, HTTP durum kodlarını ve Web Sunucusundan döndürülebilecek ilişkili mesajları listelemektedir -

Kod İleti Açıklama
100 Devam et İsteğin sadece bir kısmı sunucu tarafından alındı, ancak reddedilmediği sürece istemcinin talebe devam etmesi gerekiyor
101 Protokolleri Değiştirme Sunucu protokolü değiştirir.
200 tamam İstek tamam
201 Oluşturuldu İstek tamamlandı ve yeni bir kaynak oluşturuldu 
202 Kabul edilmiş İstek işlenmek üzere kabul edildi, ancak işlem tamamlanmadı.
203 Yetkilendirilmemiş Bilgiler
204 İçerik yok
205 İçeriği Sıfırla
206 Kısmi İçerik
300 Çoklu seçimler Bir bağlantı listesi; kullanıcı bir bağlantı seçebilir ve o konuma gidebilir. En fazla beş adres.
301 Kalıcı Olarak Taşındı İstenen sayfa yeni bir url'ye taşındı.
302 Bulundu İstenen sayfa geçici olarak yeni bir url'ye taşındı.
303 Diğerlerini Gör İstenen sayfa farklı bir url altında bulunabilir.
304 Modifiye edilmemiş
305 Proxy kullan
306 Kullanılmayan Bu kod önceki bir sürümde kullanıldı. Artık kullanılmamaktadır, ancak kod saklıdır.
307 Geçici Yeniden Yönlendirme İstenen sayfa geçici olarak yeni bir url'ye taşındı.
400 Geçersiz istek Sunucu isteği anlamadı.
401 Yetkisiz İstenen sayfanın bir kullanıcı adı ve şifreye ihtiyacı var.
402 ödeme gerekli Bu kodu henüz kullanamazsınız.
403 Yasak İstenen sayfaya erişim yasaktır
404 Bulunamadı Sunucu istenen sayfayı bulamıyor.
405 izinsiz metod Talepte belirtilen yönteme izin verilmiyor.
406 Kabul edilemez Sunucu, yalnızca istemci tarafından kabul edilmeyen bir yanıt oluşturabilir.
407 Proxy Kimlik Doğrulaması Gerekli Bu isteğin yerine getirilebilmesi için önce bir proxy sunucusuyla kimlik doğrulamanız gerekir.
408 İstek zaman aşımına uğradı İstek, sunucunun beklemeye hazırlandığından daha uzun sürdü.
409 Fikir ayrılığı Bir çakışma nedeniyle istek tamamlanamadı.
410 Gitti İstenen sayfa artık mevcut değil.
411 Uzunluk Gerekli "İçerik Uzunluğu" tanımlanmadı. Sunucu, onsuz isteği kabul etmeyecektir.
412 Ön Koşul Başarısız İstekte belirtilen ön koşul, sunucu tarafından yanlış olarak değerlendirildi.
413 girilen veri çok fazla Sunucu isteği kabul etmeyecek çünkü istek varlığı çok büyük.
414 URL isteği Çok Uzun URL çok uzun olduğu için sunucu isteği kabul etmeyecek. Bu, bir "gönderi" isteğini uzun bir sorgu bilgisine sahip bir "alma" isteğine dönüştürdüğünüzde oluşur.
415 Desteklenmeyen Medya Türü Ortam türü desteklenmediği için sunucu isteği kabul etmeyecek.
417 Beklenti Başarısız
500 İç Sunucu Hatası İstek tamamlanmadı. Sunucu beklenmedik bir koşulla karşılaştı.
501 Uygulanmadı İstek tamamlanmadı. Sunucu, gerekli işlevselliği desteklemedi.
502 Hatalı Ağ Geçidi İstek tamamlanmadı. Sunucu, yukarı akış sunucusundan geçersiz bir yanıt aldı.
503 hizmet kullanılamıyor İstek tamamlanmadı. Sunucu geçici olarak aşırı yükleniyor veya çalışmıyor.
504 Ağ Geçidi Zaman Aşımı Ağ geçidi zaman aşımına uğradı.
505 HTTP Sürümü Desteklenmiyor Sunucu, "http protocol" versiyon.

HTTP Durum Kodunu Ayarlama Yöntemleri

Sunucu uygulaması programınızda HTTP Durum Kodunu ayarlamak için aşağıdaki yöntemler kullanılabilir. Bu yöntemler HttpServletResponse nesnesiyle kullanılabilir.

S.No. Yöntem ve Açıklama
1

public void setStatus ( int statusCode )

Bu yöntem, rastgele bir durum kodu ayarlar. SetStatus yöntemi, bağımsız değişken olarak bir int (durum kodu) alır. Yanıtınız özel bir durum kodu ve bir belge içeriyorsa, aradığınızdan emin olun.setStatusİçeriğin herhangi birini PrintWriter ile gerçekten iade etmeden önce .

2

public void sendRedirect(String url)

Bu yöntem , yeni belgenin URL'sini veren bir Konum başlığı ile birlikte bir 302 yanıtı oluşturur .

3

public void sendError(int code, String message)

Bu yöntem, bir HTML belgesi içinde otomatik olarak biçimlendirilen ve istemciye gönderilen kısa bir mesajla birlikte bir durum kodu (genellikle 404) gönderir.

HTTP Durum Kodu Örneği

Aşağıdaki örnek bir 407 hata kodunun istemci tarayıcısına nasıl gönderildiğini göstermektedir. Bundan sonra, tarayıcı size "Need authentication!!!" İleti.

<html>
   <head>
      <title>Setting HTTP Status Code</title>
   </head>
   
   <body>
      <%
         // Set error code and reason.
         response.sendError(407, "Need authentication!!!" );
      %>
   </body>
</html>

Aşağıdaki çıktıyı alacaksınız -

HTTP Status 407 - Need authentication!!!

type Status report

message Need authentication!!!

description The client must first authenticate itself with the proxy (Need authentication!!!).

Apache Tomcat/5.5.29

HTTP durum kodlarıyla daha rahat olmak için, farklı durum kodları ve açıklamaları ayarlamayı deneyin.

Bu bölümde, JSP'de Form İşlemeyi tartışacağız. Tarayıcınızdan web sunucusuna ve nihayetinde arka uç programınıza bazı bilgileri aktarmanız gerektiğinde birçok durumla karşılaşmış olmalısınız. Tarayıcı, bu bilgiyi web sunucusuna iletmek için iki yöntem kullanır. Bu yöntemler GET Yöntemi ve POST Yöntemi'dir.

Form İşlemede Yöntemler

Şimdi Form İşleme'deki yöntemleri tartışalım.

GET yöntemi

GET yöntemi, sayfa isteğine eklenen kodlanmış kullanıcı bilgilerini gönderir. Sayfa ve kodlanmış bilgiler,? aşağıdaki gibi karakter -

http://www.test.com/hello?key1=value1&key2=value2

GET yöntemi, tarayıcıdan web sunucusuna bilgi iletmek için varsayılan yöntemdir ve tarayıcınızda görünen uzun bir dize oluşturur. Location:box. GET yönteminin daha iyi kullanılmaması tavsiye edilir. Sunucuya iletmek için parolanız veya diğer hassas bilgileriniz varsa.

GET yönteminin boyut sınırlaması vardır: only 1024 characters can be in a request string.

Bu bilgiler kullanılarak geçirilir QUERY_STRING header ve kullanılarak işlenebilen QUERY_STRING ortam değişkeni aracılığıyla erişilebilir olacak getQueryString() ve getParameter() istek nesnesinin yöntemleri.

POST yöntemi

Bir arka uç programına bilgi aktarmanın genellikle daha güvenilir bir yöntemi POST yöntemidir.

Bu yöntem, bilgileri GET yöntemiyle tam olarak aynı şekilde paketler, ancak bunu bir? URL'de ayrı bir mesaj olarak gönderir. Bu mesaj arka uç programına, işlemeniz için ayrıştırıp kullanabileceğiniz standart girdi biçiminde gelir.

JSP bu tür istekleri kullanarak getParameter() basit parametreleri okuma yöntemi ve getInputStream() istemciden gelen ikili veri akışını okuma yöntemi.

JSP kullanarak Form Verilerini Okuma

JSP, duruma bağlı olarak aşağıdaki yöntemleri kullanarak form verilerini otomatik olarak ayrıştırır -

  • getParameter() - Sen ara request.getParameter() bir form parametresinin değerini almak için yöntem.

  • getParameterValues() - Parametre birden fazla görünüyorsa ve birden çok değer, örneğin onay kutusu döndürüyorsa bu yöntemi çağırın.

  • getParameterNames() - Mevcut istekteki tüm parametrelerin tam bir listesini istiyorsanız bu yöntemi çağırın.

  • getInputStream() - İstemciden gelen ikili veri akışını okumak için bu yöntemi çağırın.

URL Kullanan GET Yöntemi Örneği

Aşağıdaki URL, GET yöntemini kullanarak HelloForm programına iki değer iletir.

http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI

Aşağıda main.jspWeb tarayıcısı tarafından verilen girişi işlemek için JSP programı. KullanacağızgetParameter() aktarılan bilgilere erişimi çok kolaylaştıran yöntem -

<html>
   <head>
      <title>Using GET Method to Read Form Data</title>
   </head>
   
   <body>
      <h1>Using GET Method to Read Form Data</h1>
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Şimdi yazın http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI tarayıcınızda Location:box. Bu, aşağıdaki sonucu oluşturacaktır -

Form Verilerini Okumak için GET Yöntemini Kullanma

  • First Name: ZARA

  • Last Name: ALI

Form Kullanarak GET Yöntemi Örneği

Aşağıda, HTML FORMU ve gönder düğmesini kullanarak iki değer ileten bir örnek verilmiştir. Bu girdiyi işlemek için aynı JSP main.jsp'yi kullanacağız.

<html>
   <body>
      
      <form action = "main.jsp" method = "GET">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Bu HTML'yi Hello.htm dosyasında saklayın ve içine koyun <Tomcat-installation-directory>/webapps/ROOT directory. Ne zaman erişeceksinhttp://localhost:8080/Hello.htm, aşağıdaki çıktıyı alacaksınız.

Form Kullanarak POST Yöntemi Örneği

Hem GET hem de POST yöntemini işlemek için yukarıdaki JSP'de küçük bir değişiklik yapalım. Aşağıdamain.jsp JSP programı, GET veya POST yöntemlerini kullanarak web tarayıcısı tarafından verilen girişi işlemek için.

Aslında yukarıdaki JSP'de bir değişiklik yoktur çünkü parametreleri geçirmenin tek yolu değiştirilir ve JSP programına ikili veri aktarılmaz. Dosya işlemeyle ilgili kavramlar, ikili veri akışını okumamız gereken ayrı bölümde açıklanacaktır.

<html>
   <head>
      <title>Using GET and POST Method to Read Form Data</title>
   </head>
   
   <body>
      <center>
      <h1>Using POST Method to Read Form Data</h1>
      
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Aşağıdakilerin içeriği Hello.htm dosya -

<html>
   <body>
      
      <form action = "main.jsp" method = "POST">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Şimdi tutalım main.jsp ve merhaba.htm in <Tomcat-installationdirectory>/webapps/ROOT directory. Eriştiğinizdehttp://localhost:8080/Hello.htm, aşağıdaki çıktıyı alacaksınız.

Tomcat'in çalıştığı yerel makinenizde sonucu görmek için First and Last Name'i girmeyi deneyin ve ardından gönder düğmesine tıklayın.

Sağlanan girdiye bağlı olarak, yukarıdaki örneklerde olduğu gibi benzer sonuçlar alacaksınız.

Onay Kutusu Verilerini JSP Programına Aktarma

Onay kutuları, birden fazla seçeneğin seçilmesi gerektiğinde kullanılır.

Aşağıdaki bir örnek HTML code, CheckBox.htm, iki onay kutusu olan bir form için.

<html>
   <body>
      
      <form action = "main.jsp" method = "POST" target = "_blank">
         <input type = "checkbox" name = "maths" checked = "checked" /> Maths
         <input type = "checkbox" name = "physics"  /> Physics
         <input type = "checkbox" name = "chemistry" checked = "checked" /> Chemistry
         <input type = "submit" value = "Select Subject" />
      </form>
      
   </body>
</html>

Yukarıdaki kod aşağıdaki sonucu oluşturacaktır -

Aşağıda, onay kutusu düğmesi için web tarayıcısı tarafından verilen girdiyi işlemek için main.jsp JSP programı verilmiştir.

<html>
   <head>
      <title>Reading Checkbox Data</title>
   </head>
   
   <body>
      <h1>Reading Checkbox Data</h1>
      
      <ul>
         <li><p><b>Maths Flag:</b>
            <%= request.getParameter("maths")%>
         </p></li>
         <li><p><b>Physics Flag:</b>
            <%= request.getParameter("physics")%>
         </p></li>
         <li><p><b>Chemistry Flag:</b>
            <%= request.getParameter("chemistry")%>
         </p></li>
      </ul>
   
   </body>
</html>

Yukarıdaki program aşağıdaki sonucu üretecektir -

Reading Checkbox Data

  • Maths Flag :: on

  • Physics Flag:: null

  • Chemistry Flag:: on

Tüm Form Parametrelerini Okuma

Aşağıda, kullanan genel bir örnek yer almaktadır. getParameterNames()Kullanılabilir tüm form parametrelerini okumak için HttpServletRequest yöntemi. Bu yöntem, parametre adlarını belirtilmemiş bir sırada içeren bir Numaralandırma döndürür.

Bir Numaralandırmaya sahip olduğumuzda, Numaralamayı standart bir şekilde aşağı çevirebiliriz. hasMoreElements() ne zaman duracağını ve kullanacağını belirleme yöntemi nextElement() her parametre adını alma yöntemi.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>HTTP Header Request Example</title>
   </head>

   <body>
      <center>
         <h2>HTTP Header Request Example</h2>
         <table width = "100%" border = "1" align = "center">
            <tr bgcolor = "#949494">
               <th>Param Name</th>
               <th>Param Value(s)</th>
            </tr>
            <%
               Enumeration paramNames = request.getParameterNames();
               while(paramNames.hasMoreElements()) {
                  String paramName = (String)paramNames.nextElement();
                  out.print("<tr><td>" + paramName + "</td>\n");
                  String paramValue = request.getHeader(paramName);
                  out.println("<td> " + paramValue + "</td></tr>\n");
               }
            %>
         </table>
      </center>
   
   </body>
</html>

Aşağıdakilerin içeriği Hello.htm -

<html>
   <body>
      
      <form action = "main.jsp" method = "POST" target = "_blank">
         <input type = "checkbox" name = "maths" checked = "checked" /> Maths
         <input type = "checkbox" name = "physics"  /> Physics
         <input type = "checkbox" name = "chemistry" checked = "checked" /> Chem
         <input type = "submit" value = "Select Subject" />
      </form>
   
   </body>
</html>

Şimdi yukarıdaki Hello.htm'yi kullanarak JSP'yi aramayı deneyin; bu, sağlanan girdiye dayalı olarak aşağıdaki gibi bir sonuç üretecektir -

Tüm Form Parametrelerini Okuma

Param Adı Parametre Değerleri
Matematik açık
kimya açık

Metin kutusu, radyo düğmesi veya açılır menü vb. Gibi diğer nesnelerin bulunduğu başka herhangi bir formun verilerini okumak için yukarıdaki JSP'yi deneyebilirsiniz.

Bu bölümde, JSP'deki Filtreleri tartışacağız. Servlet ve JSP Filtreleri, aşağıdaki amaçlarla Servlet ve JSP Programlamada kullanılabilen Java sınıflarıdır -

  • Arka uçta bir kaynağa erişmeden önce istemciden gelen istekleri engellemek için.

  • İstemciye geri gönderilmeden önce sunucudan gelen yanıtları değiştirmek için.

Spesifikasyonların önerdiği çeşitli filtre türleri vardır -

  • Kimlik Doğrulama Filtreleri
  • Veri sıkıştırma Filtreleri
  • Şifreleme Filtreleri
  • Kaynak erişim olaylarını tetikleyen filtreler
  • Görüntü Dönüştürme Filtreleri
  • Günlük Kaydı ve Denetleme Filtreleri
  • MIME-TYPE Zincir Filtreleri
  • Tokenleştirme Filtreleri
  • XML İçeriğini Dönüştüren XSL / T Filtreleri

Filtreler, dağıtım tanımlayıcı dosyasında dağıtılır web.xmlve sonra uygulamanızın dağıtım tanımlayıcısındaki sunucu uygulaması veya JSP adlarıyla veya URL modelleriyle eşleyin. Web.xml dağıtım tanımlayıcı dosyası <Tomcat-installation-directory> \ conf dizininde bulunabilir.

JSP kapsayıcısı web uygulamanızı başlattığında, dağıtım tanımlayıcısında beyan ettiğiniz her filtrenin bir örneğini oluşturur. Filtreler, dağıtım tanımlayıcısında bildirildikleri sırayla yürütülür.

Servlet Filtre Yöntemleri

Bir filtre, basitçe, javax.servlet.Filterarayüz. Javax.servlet.Filter arabirimi üç yöntem tanımlar -

S.No. Yöntem ve Açıklama
1

public void doFilter (ServletRequest, ServletResponse, FilterChain)

Bu yöntem, zincirin sonundaki bir kaynak için bir istemci talebi nedeniyle zincirden bir istek / yanıt çifti her geçtiğinde konteyner tarafından çağrılır.

2

public void init(FilterConfig filterConfig)

Bu yöntem, hizmete konulmakta olduğunu bir filtreye belirtmek için web kapsayıcısı tarafından çağrılır.

3

public void destroy()

Bu yöntem, hizmet dışı bırakıldığını bir filtreye belirtmek için web kapsayıcısı tarafından çağrılır.

JSP Filtre Örneği

Aşağıdaki örnek, herhangi bir JSP dosyasına her eriştiğinde istemcinin IP adresini ve geçerli tarih saatini nasıl yazdıracağını gösterir. Bu örnek size JSP Filtresi hakkında temel bir anlayış verecektir, ancak aynı konsepti kullanarak daha karmaşık filtre uygulamaları yazabilirsiniz -

// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
 
// Implements Filter class
public class LogFilter implements Filter  {
   public void  init(FilterConfig config) throws ServletException {
      // Get init parameter 
      String testParam = config.getInitParameter("test-param"); 
 
      //Print the init parameter 
      System.out.println("Test Param: " + testParam); 
   }
   public void  doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
      throws java.io.IOException, ServletException {
      
      // Get the IP address of client machine.   
      String ipAddress = request.getRemoteAddr();
      
      // Log the IP address and current timestamp.
      System.out.println("IP "+ ipAddress + ", Time "+ new Date().toString());
      
      // Pass request back down the filter chain
      chain.doFilter(request,response);
   }
   public void destroy( ) {
      /* Called before the Filter instance is removed 
      from service by the web container*/
   }
}

Derleme LogFilter.java her zamanki gibi ve koy LogFilter.class dosyasında <Tomcat-installation-directory>/webapps/ROOT/WEB-INF/classes.

Web.xml'de JSP Filtre Eşlemesi

Filtreler tanımlanır ve ardından bir URL veya JSP dosya adına eşlenir, tıpkı Servlet'in tanımlanmasıyla aynı şekilde ve daha sonra web.xmldosya. Dağıtım tanımlayıcı dosyasında filtre etiketi için aşağıdaki girişi oluşturunweb.xml

<filter>
   <filter-name>LogFilter</filter-name>
   <filter-class>LogFilter</filter-class>
   
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>

<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Yukarıdaki filtre tüm sunucu uygulamaları ve JSP için geçerli olacaktır çünkü /*konfigürasyonumuzda. Yalnızca birkaç sunucu uygulamasına veya JSP'ye filtre uygulamak istiyorsanız, belirli bir sunucu uygulamasını veya JSP yolunu belirtebilirsiniz.

Şimdi herhangi bir sunucu uygulamasını veya JSP'yi çağırmayı deneyin ve web sunucusu günlüğünüzde oluşturulan günlüğü göreceksiniz. KullanabilirsinizLog4J logger ayrı bir dosyada oturum açmak için.

Birden Çok Filtre Kullanmak

Web uygulamanız, belirli bir amaç için birkaç farklı filtre tanımlayabilir. AuthenFilter ve LogFilter olmak üzere iki filtre tanımladığınızı düşünün . Aşağıda belirtildiği gibi farklı bir eşleme oluşturmanız gerekmesi dışında, işlemin geri kalanı yukarıda açıklandığı gibi kalacaktır -

<filter>
   <filter-name>LogFilter</filter-name>
   <filter-class>LogFilter</filter-class>
   
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>
 
<filter>
   <filter-name>AuthenFilter</filter-name>
   <filter-class>AuthenFilter</filter-class>
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>
 
<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>
 
<filter-mapping>
   <filter-name>AuthenFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Filtreler Uygulama Sırası

Web.xml'deki filtre eşleme öğelerinin sırası, web kapsayıcısının filtreyi sunucu uygulamasına veya JSP'ye uygulama sırasını belirler. Filtrenin sırasını tersine çevirmek için, filtredeki filtre eşleme öğelerini tersine çevirmeniz yeterlidir.web.xml dosya.

Örneğin, yukarıdaki örnek önce LogFilter'ı uygulayacak ve ardından AuthenFilter'ı herhangi bir sunucu uygulamasına veya JSP'ye uygulayacaktır; aşağıdaki örnek sıralamayı tersine çevirecektir -

<filter-mapping>
   <filter-name>AuthenFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>
 
<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Bu bölümde, JSP'de Çerez Kullanımı konusunu ele alacağız. Çerezler, istemci bilgisayarda saklanan metin dosyalarıdır ve çeşitli bilgi izleme amaçları için saklanırlar. JSP, temeldeki sunucu uygulaması teknolojisini kullanarak HTTP tanımlama bilgilerini şeffaf bir şekilde destekler.

Kullanıcıların belirlenmesi ve geri verilmesinin üç adımı vardır -

  • Sunucu komut dosyası, tarayıcıya bir dizi çerez gönderir. Örneğin isim, yaş veya kimlik numarası vb.

  • Tarayıcı, bu bilgileri ileride kullanılmak üzere yerel makinede depolar.

  • Tarayıcı web sunucusuna bir dahaki sefere herhangi bir istek gönderdiğinde, bu tanımlama bilgilerini sunucuya gönderir ve sunucu bu bilgileri kullanıcıyı tanımlamak için kullanır veya başka bir amaçla da olabilir.

Bu bölüm size tanımlama bilgilerini nasıl ayarlayacağınızı veya sıfırlayacağınızı, bunlara nasıl erişeceğinizi ve JSP programlarını kullanarak nasıl sileceğinizi öğretecektir.

Bir Çerezin Anatomisi

Çerezler genellikle bir HTTP başlığında ayarlanır (bununla birlikte JavaScript, doğrudan bir tarayıcıya da bir çerez ayarlayabilir). Bir çerez ayarlayan bir JSP, şuna benzer başlıklar gönderebilir -

HTTP/1.1 200 OK
Date: Fri, 04 Feb 2000 21:03:38 GMT
Server: Apache/1.3.9 (UNIX) PHP/4.0b3
Set-Cookie: name = xyz; expires = Friday, 04-Feb-07 22:03:38 GMT; 
   path = /; domain = tutorialspoint.com
Connection: close
Content-Type: text/html

Gördüğünüz gibi Set-Cookie header içerir a name value pair, a GMT date, a path ve a domain. Ad ve değer URL olarak kodlanacaktır. expires alan, tarayıcıya bir talimattır. "forget" verilen saat ve tarihten sonraki çerez.

Tarayıcı tanımlama bilgilerini depolayacak şekilde yapılandırılmışsa, bu bilgileri son kullanma tarihine kadar saklayacaktır. Kullanıcı, tarayıcıyı çerezin yolu ve etki alanıyla eşleşen herhangi bir sayfaya yönlendirirse, çerezi sunucuya yeniden gönderir. Tarayıcının başlıkları şöyle görünebilir -

GET / HTTP/1.0
Connection: Keep-Alive
User-Agent: Mozilla/4.6 (X11; I; Linux 2.2.6-15apmac ppc)
Host: zink.demon.co.uk:1126

Accept: image/gif, */*
Accept-Encoding: gzip
Accept-Language: en
Accept-Charset: iso-8859-1,*,utf-8
Cookie: name = xyz

Bir JSP komut dosyası, istek yöntemi aracılığıyla tanımlama bilgilerine erişebilir. request.getCookies()bir dizi Cookie nesnesi döndürür .

Servlet Çerez Yöntemleri

Aşağıdaki tablo, JSP'de çerezleri işlerken kullanabileceğiniz Çerez nesnesiyle ilişkili yararlı yöntemleri listelemektedir -

S.No. Yöntem ve Açıklama
1

public void setDomain(String pattern)

Bu yöntem, çerezin uygulanacağı alanı belirler; örneğin, tutorialspoint.com.

2

public String getDomain()

Bu yöntem, çerezin geçerli olduğu alanı alır; örneğin, tutorialspoint.com.

3

public void setMaxAge(int expiry)

Bu yöntem, çerezin süresi dolmadan önce ne kadar sürenin (saniye cinsinden) geçmesi gerektiğini belirler. Bunu ayarlamazsanız, çerez yalnızca mevcut oturum için geçerli olacaktır.

4

public int getMaxAge()

Bu yöntem, çerezin saniye cinsinden belirtilen maksimum yaşını döndürür, Varsayılan olarak, -1 çerezin tarayıcı kapanana kadar devam edeceğini belirtir.

5

public String getName()

Bu yöntem, çerezin adını döndürür. İsim oluşturulduktan sonra değiştirilemez.

6

public void setValue(String newValue)

Bu yöntem, tanımlama bilgisi ile ilişkili değeri ayarlar.

7

public String getValue()

Bu yöntem, çerezle ilişkilendirilen değeri alır.

8

public void setPath(String uri)

Bu yöntem, bu tanımlama bilgisinin uygulanacağı yolu belirler. Bir yol belirtmezseniz, çerez geçerli sayfayla aynı dizindeki tüm URL'ler ve tüm alt dizinler için döndürülür.

9

public String getPath()

Bu yöntem, bu çerezin uygulandığı yolu alır.

10

public void setSecure(boolean flag)

Bu yöntem, tanımlama bilgisinin yalnızca şifreli (yani, SSL) bağlantılar üzerinden gönderilip gönderilmeyeceğini belirten boole değerini ayarlar.

11

public void setComment(String purpose)

Bu yöntem, bir tanımlama bilgisinin amacını açıklayan bir yorumu belirtir. Tarayıcının çerezi kullanıcıya sunması durumunda yorum yararlıdır.

12

public String getComment()

Bu yöntem, bu tanımlama bilgisinin amacını açıklayan yorumu döndürür veya tanımlama bilgisinin açıklaması yoksa boş bırakılır.

JSP ile Çerezleri Ayarlama

JSP ile tanımlama bilgileri ayarlamak üç adımdan oluşur -

Adım 1: Bir Çerez nesnesi oluşturma

Tanımlama bilgisi yapıcısını, her ikisi de dize olan bir tanımlama bilgisi adı ve tanımlama bilgisi değeri ile çağırırsınız.

Cookie cookie = new Cookie("key","value");

Adın veya değerin beyaz boşluk veya aşağıdaki karakterlerden herhangi birini içermemesi gerektiğini unutmayın -

[ ] ( ) = , " / ? @ : ;

Adım 2: Maksimum yaşın ayarlanması

Kullan setMaxAgeçerezin ne kadar süre (saniye olarak) geçerli olması gerektiğini belirtmek için. Aşağıdaki kod, 24 saat için bir çerez ayarlayacaktır.

cookie.setMaxAge(60*60*24);

Adım 3: Çerezi HTTP yanıt başlıklarına gönderme

Kullan response.addCookie HTTP yanıt başlığına aşağıdaki gibi tanımlama bilgileri eklemek için

response.addCookie(cookie);

Misal

Ad ve soyad için tanımlama bilgilerini ayarlamak için Form Örneğimizi değiştirelim .

<%
   // Create cookies for first and last names.      
   Cookie firstName = new Cookie("first_name", request.getParameter("first_name"));
   Cookie lastName = new Cookie("last_name", request.getParameter("last_name"));
   
   // Set expiry date after 24 Hrs for both the cookies.
   firstName.setMaxAge(60*60*24); 
   lastName.setMaxAge(60*60*24); 
   
   // Add both the cookies in the response header.
   response.addCookie( firstName );
   response.addCookie( lastName );
%>

<html>
   <head>
      <title>Setting Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Setting Cookies</h1>
      </center>
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Yukarıdaki kodu buraya koyalım main.jsp dosyasını açın ve aşağıdaki HTML sayfasında kullanın -

<html>
   <body>
      
      <form action = "main.jsp" method = "GET">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Yukarıdaki HTML içeriğini bir dosyada saklayın hello.jsp ve koy hello.jsp ve main.jsp içinde <Tomcat-installation-directory>/webapps/ROOTdizin. Ne zaman erişeceksinhttp://localhost:8080/hello.jsp, işte yukarıdaki formun gerçek çıktısı.

Adı ve Soyadı girmeyi deneyin ve ardından gönder düğmesine tıklayın. Bu, ekranınızda ilk adı ve soyadı gösterecek ve ayrıca iki çerez ayarlayacaktır.firstName ve lastName. Bu çerezler, Gönder düğmesine bir sonraki tıkladığınızda sunucuya geri gönderilecektir.

Bir sonraki bölümde, bu çerezlere web uygulamanıza nasıl erişebileceğinizi açıklayacağız.

JSP ile Çerezleri Okuma

Çerezleri okumak için, bir dizi javax.servlet.http.Cookie nesnesini çağırarak oluşturmanız gerekir .getCookies( )HttpServletRequest yöntemi . Ardından dizide dolaşın vegetName() ve getValue() her çereze ve ilişkili değere erişim yöntemleri.

Misal

Şimdi önceki örnekte ayarlanan çerezleri okuyalım -

<html>
   <head>
      <title>Reading Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Reading Cookies</h1>
      </center>
      <%
         Cookie cookie = null;
         Cookie[] cookies = null;
         
         // Get an array of Cookies associated with the this domain
         cookies = request.getCookies();
         
         if( cookies != null ) {
            out.println("<h2> Found Cookies Name and Value</h2>");
            
            for (int i = 0; i < cookies.length; i++) {
               cookie = cookies[i];
               out.print("Name : " + cookie.getName( ) + ",  ");
               out.print("Value: " + cookie.getValue( )+" <br/>");
            }
         } else {
            out.println("<h2>No cookies founds</h2>");
         }
      %>
   </body>
   
</html>

Şimdi yukarıdaki kodu yerine koyalım main.jspdosya ve erişmeye çalışın. Eğer ayarlarsanızfirst_name cookie "John" olarak ve last_name cookie "Oyuncu" olarak sonra çalışıyor http://localhost:8080/main.jsp aşağıdaki sonucu gösterecek -

Found Cookies Name and Value

Name : first_name, Value: John

Name : last_name, Value: Player

JSP ile Çerezleri Silin

Çerezleri silmek çok basittir. Bir çerezi silmek istiyorsanız, şu üç adımı izlemeniz yeterlidir -

  • Zaten var olan bir çerezi okuyun ve Çerez nesnesinde saklayın.

  • Çerez yaşını sıfır olarak ayarlayın setMaxAge() mevcut bir çerezi silme yöntemi.

  • Bu çerezi yanıt başlığına geri ekleyin.

Misal

Aşağıdaki örnek, adlı mevcut bir çerezi nasıl sileceğinizi gösterecektir. "first_name" ve main.jsp JSP'yi bir dahaki sefere çalıştırdığınızda, ilk_ad için boş değer döndürür.

<html>
   <head>
      <title>Reading Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Reading Cookies</h1>
      </center>
      <%
         Cookie cookie = null;
         Cookie[] cookies = null;
         
         // Get an array of Cookies associated with the this domain
         cookies = request.getCookies();
         
         if( cookies != null ) {
            out.println("<h2> Found Cookies Name and Value</h2>");
            
            for (int i = 0; i < cookies.length; i++) {
               cookie = cookies[i];
               
               if((cookie.getName( )).compareTo("first_name") == 0 ) {
                  cookie.setMaxAge(0);
                  response.addCookie(cookie);
                  out.print("Deleted cookie: " + 
                  cookie.getName( ) + "<br/>");
               }
               out.print("Name : " + cookie.getName( ) + ",  ");
               out.print("Value: " + cookie.getValue( )+" <br/>");
            }
         } else {
            out.println(
            "<h2>No cookies founds</h2>");
         }
      %>
   </body>
   
</html>

Şimdi yukarıdaki kodu main.jspdosya ve erişmeye çalışın. Aşağıdaki sonucu gösterecektir -

Cookies Name and Value

Deleted cookie : first_name

Name : first_name, Value: John

Name : last_name, Value: Player

Şimdi http: // localhost: 8080 / main.jsp'yi bir kez daha çalıştırın ve aşağıdaki gibi yalnızca bir çerez göstermelidir -

Found Cookies Name and Value

Name : last_name, Value: Player

Tanımlama bilgilerinizi Internet Explorer'da manuel olarak silebilirsiniz. Araçlar menüsünden başlayın ve İnternet Seçeneklerini seçin. Tüm tanımlama bilgilerini silmek için Tanımlama Bilgilerini Sil düğmesini tıklayın.

Bu bölümde, JSP'de oturum takibini tartışacağız. HTTP "durumsuz" bir protokoldür, yani bir istemci bir Web sayfasını her aldığında, istemci Web sunucusuna ayrı bir bağlantı açar ve sunucu otomatik olarak önceki istemci isteğinin kaydını tutmaz.

Web İstemcisi ve Sunucu Arasındaki Oturumu Sürdürme

Şimdi Web İstemcisi ile Web Sunucusu arasındaki oturumu sürdürmek için birkaç seçeneği tartışalım -

Kurabiye

Bir web sunucusu, her web istemcisine tanımlama bilgisi olarak benzersiz bir oturum kimliği atayabilir ve istemciden gelen sonraki istekler, alınan tanımlama bilgisi kullanılarak tanınabilir.

Tarayıcı zaman zaman bir çerezi desteklemediğinden, bu etkili bir yol olmayabilir. Seansları sürdürmek için bu prosedürün kullanılması önerilmez.

Gizli Form Alanları

Bir web sunucusu, aşağıdaki gibi benzersiz bir oturum kimliğiyle birlikte gizli bir HTML form alanı gönderebilir -

<input type = "hidden" name = "sessionid" value = "12345">

Bu giriş, form gönderildiğinde, belirtilen ad ve değerin otomatik olarak GET ya da POSTveri. Web tarayıcısı isteği her geri gönderdiğinde,session_id değeri, farklı web tarayıcılarının izini sürmek için kullanılabilir.

Bu, oturumu takip etmenin etkili bir yolu olabilir, ancak normal (<A HREF...>) bir köprü metni bağlantısına tıklamak bir form gönderimi ile sonuçlanmaz, bu nedenle gizli form alanları da genel oturum izlemeyi destekleyemez.

URL Yeniden Yazma

Her URL'nin sonuna fazladan bazı veriler ekleyebilirsiniz. Bu veriler oturumu tanımlar; sunucu, bu oturum tanımlayıcısını o oturum hakkında depoladığı verilerle ilişkilendirebilir.

Örneğin http://tutorialspoint.com/file.htm;sessionid=12345oturum tanımlayıcısı şu şekilde eklenir: sessionid = 12345 istemciyi tanımlamak için web sunucusundan erişilebilir.

URL yeniden yazma, oturumları sürdürmenin daha iyi bir yoludur ve tarayıcılar çerezleri desteklemediğinde işe yarar. Buradaki dezavantaj, sayfa basit bir statik HTML sayfası olsa da, bir oturum kimliği atamak için her URL'yi dinamik olarak oluşturmanız gerekecek olmasıdır.

Oturum Nesnesi

Yukarıda bahsedilen seçeneklerden ayrı olarak, JSP, sunucu uygulamasıyla sağlanan HttpSession Arayüzünü kullanır. Bu arayüz, bir kullanıcıyı tanımlamanın bir yolunu sağlar.

  • tek sayfalık bir istek veya
  • bir web sitesini ziyaret edin veya
  • o kullanıcı hakkında bilgi depolamak

Varsayılan olarak, JSP'lerde oturum izleme etkindir ve her yeni istemci için otomatik olarak yeni bir HttpSession nesnesi oluşturulur. Oturum izlemeyi devre dışı bırakmak, sayfa yönergesi oturum özniteliğini aşağıdaki gibi false olarak ayarlayarak açık bir şekilde kapatmayı gerektirir -

<%@ page session = "false" %>

JSP motoru, HttpSession nesnesini JSP yazarına örtük olarak gösterir sessionnesne. Dan berisession nesne zaten JSP programlayıcısına sağlanmışsa, programcı herhangi bir başlatma olmadan nesneden verileri depolamaya ve geri almaya hemen başlayabilir veya getSession().

İşte oturum nesnesi aracılığıyla kullanılabilen önemli yöntemlerin bir özeti:

S.No. Yöntem ve Açıklama
1

public Object getAttribute(String name)

Bu yöntem, bu oturumda belirtilen adla ilişkili nesneyi döndürür veya ad altında hiçbir nesne bağlı değilse null.

2

public Enumeration getAttributeNames()

Bu yöntem, bu oturuma bağlı tüm nesnelerin adlarını içeren String nesnelerinin Numaralandırılmasını döndürür.

3

public long getCreationTime()

Bu yöntem, 1 Ocak 1970 GMT gece yarısından itibaren milisaniye cinsinden ölçülen bu oturumun oluşturulduğu zamanı döndürür.

4

public String getId()

Bu yöntem, bu oturuma atanan benzersiz tanımlayıcıyı içeren bir dize döndürür.

5

public long getLastAccessedTime()

Bu yöntem, 1 Ocak 1970 GMT gece yarısından bu yana geçen milisaniye sayısı olarak, istemcinin bu oturumla ilişkili en son istek gönderdiği zamanı döndürür.

6

public int getMaxInactiveInterval()

Bu yöntem, sunucu uygulamacığının bu oturumu istemci erişimleri arasında açık tutacağı maksimum zaman aralığını saniye cinsinden döndürür.

7

public void invalidate()

Bu yöntem, bu oturumu geçersiz kılar ve ona bağlı tüm nesnelerin bağlantısını kaldırır.

8

public boolean isNew()

İstemci oturumu henüz bilmiyorsa veya oturuma katılmamayı seçerse bu yöntem true döndürür.

9

public void removeAttribute(String name)

Bu yöntem, belirtilen adla bağlı nesneyi bu oturumdan kaldırır.

10

public void setAttribute(String name, Object value)

Bu yöntem, belirtilen adı kullanarak bir nesneyi bu oturuma bağlar.

11

public void setMaxInactiveInterval(int interval)

Bu yöntem, sunucu uygulaması kapsayıcısının bu oturumu geçersiz kılmasından önce istemci istekleri arasındaki süreyi saniye cinsinden belirtir.

Oturum İzleme Örneği

Bu örnek, bir oturum için oluşturma zamanını ve son erişilen zamanı bulmak için HttpSession nesnesinin nasıl kullanılacağını açıklar. Zaten mevcut değilse, yeni bir oturumu istekle ilişkilendiririz.

<%@ page import = "java.io.*,java.util.*" %>
<%
   // Get session creation time.
   Date createTime = new Date(session.getCreationTime());
   
   // Get last access time of this Webpage.
   Date lastAccessTime = new Date(session.getLastAccessedTime());

   String title = "Welcome Back to my website";
   Integer visitCount = new Integer(0);
   String visitCountKey = new String("visitCount");
   String userIDKey = new String("userID");
   String userID = new String("ABCD");

   // Check if this is new comer on your Webpage.
   if (session.isNew() ){
      title = "Welcome to my website";
      session.setAttribute(userIDKey, userID);
      session.setAttribute(visitCountKey,  visitCount);
   } 
   visitCount = (Integer)session.getAttribute(visitCountKey);
   visitCount = visitCount + 1;
   userID = (String)session.getAttribute(userIDKey);
   session.setAttribute(visitCountKey,  visitCount);
%>

<html>
   <head>
      <title>Session Tracking</title>
   </head>
   
   <body>
      <center>
         <h1>Session Tracking</h1>
      </center>
      
      <table border = "1" align = "center"> 
         <tr bgcolor = "#949494">
            <th>Session info</th>
            <th>Value</th>
         </tr> 
         <tr>
            <td>id</td>
            <td><% out.print( session.getId()); %></td>
         </tr> 
         <tr>
            <td>Creation Time</td>
            <td><% out.print(createTime); %></td>
         </tr> 
         <tr>
            <td>Time of Last Access</td>
            <td><% out.print(lastAccessTime); %></td>
         </tr> 
         <tr>
            <td>User ID</td>
            <td><% out.print(userID); %></td>
         </tr> 
         <tr>
            <td>Number of visits</td>
            <td><% out.print(visitCount); %></td>
         </tr> 
      </table> 
   
   </body>
</html>

Şimdi yukarıdaki kodu yerleştirin main.jsp ve erişmeyi dene http://localhost:8080/main.jsp. URL'yi çalıştırdığınızda, aşağıdaki sonucu alacaksınız -

Web siteme hoş geldiniz

Session Information

Oturum bilgileri değer
İD 0AE3EC93FF44E3C525B4351B77ABB2D5
Oluşturma Zamanı Salı 08 Haziran 17:26:40 GMT + 04: 00 2010
Son Erişim Zamanı Salı 08 Haziran 17:26:40 GMT + 04: 00 2010
Kullanıcı kimliği ABCD
Ziyaret sayısı 0

Şimdi aynı JSP'yi ikinci kez çalıştırmayı deneyin, aşağıdaki sonucu alacaksınız.

Web siteme tekrar hoş geldiniz

Session Information

bilgi türü değer
İD 0AE3EC93FF44E3C525B4351B77ABB2D5
Oluşturma Zamanı Salı 08 Haziran 17:26:40 GMT + 04: 00 2010
Son Erişim Zamanı Salı 08 Haziran 17:26:40 GMT + 04: 00 2010
Kullanıcı kimliği ABCD
Ziyaret sayısı 1

Oturum Verilerini Silme

Bir kullanıcının oturum verileriyle işiniz bittiğinde, birkaç seçeneğiniz vardır -

  • Remove a particular attribute - Arayabilirsiniz public void removeAttribute(String name) belirli bir anahtarla ilişkili değeri silme yöntemi.

  • Delete the whole session - Arayabilirsiniz public void invalidate() tüm bir oturumu iptal etme yöntemi.

  • Setting Session timeout - Arayabilirsiniz public void setMaxInactiveInterval(int interval) bir oturum için zaman aşımını ayrı ayrı ayarlama yöntemi.

  • Log the user out - Servlet 2.4'ü destekleyen sunucuları arayabilirsiniz logout istemcinin Web sunucusundaki oturumunu kapatmak ve tüm kullanıcılara ait tüm oturumları geçersiz kılmak için.

  • web.xml Configuration - Tomcat kullanıyorsanız, yukarıda belirtilen yöntemlerin dışında, oturum zaman aşımını web.xml dosyasında aşağıdaki gibi yapılandırabilirsiniz.

<session-config>
   <session-timeout>15</session-timeout>
</session-config>

Zaman aşımı dakika olarak ifade edilir ve Tomcat'te 30 dakika olan varsayılan zaman aşımını geçersiz kılar.

getMaxInactiveInterval( )bir sunucu uygulamasındaki yöntem, bu oturum için saniye cinsinden zaman aşımı süresini döndürür. Dolayısıyla, oturumunuz web.xml'de 15 dakika için yapılandırılırsa,getMaxInactiveInterval( ) 900 döndürür.

Bu bölümde, JSP'de Dosya Yüklemeyi tartışacağız. JSP, kullanıcıların sunucuya dosya yüklemesine izin vermek için bir HTML form etiketiyle birlikte kullanılabilir. Yüklenen bir dosya bir metin dosyası veya bir ikili dosya veya bir görüntü dosyası veya herhangi bir belge olabilir.

Dosya Yükleme Formu Oluşturma

Şimdi bir dosya yükleme formunun nasıl oluşturulacağını anlayalım. Aşağıdaki HTML kodu bir yükleyici formu oluşturur. Dikkat edilmesi gereken önemli noktalar aşağıdadır:

  • Form method özellik şu şekilde ayarlanmalıdır: POST yöntem ve GET yöntemi kullanılamaz.

  • Form enctype özellik şu şekilde ayarlanmalıdır: multipart/form-data.

  • Form actionözniteliği, arka uç sunucusunda dosya yüklemeyi işleyecek bir JSP dosyasına ayarlanmalıdır. Aşağıdaki örnek kullanıyoruploadFile.jsp dosya yüklemek için program dosyası.

  • Tek bir dosya yüklemek için tek bir dosya kullanmalısınız <input .../> niteliğe sahip etiket type = "file". Birden çok dosyanın yüklenmesine izin vermek için, ad özelliği için farklı değerlere sahip birden fazla giriş etiketi ekleyin. Tarayıcı, her biriyle bir Göz At düğmesini ilişkilendirir.

<html>
   <head>
      <title>File Uploading Form</title>
   </head>
   
   <body>
      <h3>File Upload:</h3>
      Select a file to upload: <br />
      <form action = "UploadServlet" method = "post"
         enctype = "multipart/form-data">
         <input type = "file" name = "file" size = "50" />
         <br />
         <input type = "submit" value = "Upload File" />
      </form>
   </body>
   
</html>

Bu, aşağıdaki sonucu gösterecektir. Artık yerel bilgisayardan bir dosya seçebilirsiniz ve kullanıcı "Dosya Yükle" yi tıkladığında, form seçilen dosyayla birlikte gönderilir -

File Upload

Select a file to upload −



NOTE - Yukarıdaki form sadece kukla formdur ve çalışmaz, çalışmasını sağlamak için makinenizde yukarıdaki kodu denemelisiniz.

Arka Uç JSP Komut Dosyası Yazma

Şimdi yüklenen dosyaların depolanacağı bir konum tanımlayalım. Bunu programınızda sabit olarak kodlayabilirsiniz veya bu dizin adı ayrıca bir harici yapılandırma kullanılarak eklenebilir.context-param web.xml'deki öğe aşağıdaki gibidir -

<web-app>
....
<context-param> 
   <description>Location to store uploaded file</description> 
   <param-name>file-upload</param-name> 
   <param-value>
      c:\apache-tomcat-5.5.29\webapps\data\
   </param-value> 
</context-param>
....
</web-app>

Aşağıdakiler için kaynak kodu UploadFile.jsp. Bu, aynı anda birden fazla dosyanın yüklenmesini sağlayabilir. Şimdi dosyaları yüklemeye geçmeden önce aşağıdakileri ele alalım.

  • Aşağıdaki örnek şunlara bağlıdır: FileUpload; en son sürümüne sahip olduğunuzdan emin oluncommons-fileupload.x.x.jarsınıf yolunuzdaki dosya. Buradan indirebilirsinizhttps://commons.apache.org/fileupload/.

  • FileUpload Commons IO'ya bağlıdır; en son sürümüne sahip olduğunuzdan emin oluncommons-io-x.x.jarsınıf yolunuzdaki dosya. Buradan indirebilirsinizhttps://commons.apache.org/io/.

  • Aşağıdaki örneği test ederken, maxFileSize boyutundan daha küçük bir dosya yüklemelisiniz, aksi takdirde dosya yüklenmeyecektir.

  • Dizinler oluşturduğunuzdan emin olun c:\temp ve c:\apache-tomcat5.5.29\webapps\data Peşinen.

<%@ page import = "java.io.*,java.util.*, javax.servlet.*" %>
<%@ page import = "javax.servlet.http.*" %>
<%@ page import = "org.apache.commons.fileupload.*" %>
<%@ page import = "org.apache.commons.fileupload.disk.*" %>
<%@ page import = "org.apache.commons.fileupload.servlet.*" %>
<%@ page import = "org.apache.commons.io.output.*" %>

<%
   File file ;
   int maxFileSize = 5000 * 1024;
   int maxMemSize = 5000 * 1024;
   ServletContext context = pageContext.getServletContext();
   String filePath = context.getInitParameter("file-upload");

   // Verify the content type
   String contentType = request.getContentType();
   
   if ((contentType.indexOf("multipart/form-data") >= 0)) {
      DiskFileItemFactory factory = new DiskFileItemFactory();
      // maximum size that will be stored in memory
      factory.setSizeThreshold(maxMemSize);
      
      // Location to save data that is larger than maxMemSize.
      factory.setRepository(new File("c:\\temp"));

      // Create a new file upload handler
      ServletFileUpload upload = new ServletFileUpload(factory);
      
      // maximum file size to be uploaded.
      upload.setSizeMax( maxFileSize );
      
      try { 
         // Parse the request to get file items.
         List fileItems = upload.parseRequest(request);

         // Process the uploaded file items
         Iterator i = fileItems.iterator();

         out.println("<html>");
         out.println("<head>");
         out.println("<title>JSP File upload</title>");  
         out.println("</head>");
         out.println("<body>");
         
         while ( i.hasNext () ) {
            FileItem fi = (FileItem)i.next();
            if ( !fi.isFormField () ) {
               // Get the uploaded file parameters
               String fieldName = fi.getFieldName();
               String fileName = fi.getName();
               boolean isInMemory = fi.isInMemory();
               long sizeInBytes = fi.getSize();
            
               // Write the file
               if( fileName.lastIndexOf("\\") >= 0 ) {
                  file = new File( filePath + 
                  fileName.substring( fileName.lastIndexOf("\\"))) ;
               } else {
                  file = new File( filePath + 
                  fileName.substring(fileName.lastIndexOf("\\")+1)) ;
               }
               fi.write( file ) ;
               out.println("Uploaded Filename: " + filePath + 
               fileName + "<br>");
            }
         }
         out.println("</body>");
         out.println("</html>");
      } catch(Exception ex) {
         System.out.println(ex);
      }
   } else {
      out.println("<html>");
      out.println("<head>");
      out.println("<title>Servlet upload</title>");  
      out.println("</head>");
      out.println("<body>");
      out.println("<p>No file uploaded</p>"); 
      out.println("</body>");
      out.println("</html>");
   }
%>

Şimdi, yukarıda oluşturduğunuz HTML formunu kullanarak dosyaları yüklemeyi deneyin. Denediğindehttp://localhost:8080/UploadFile.htm, aşağıdaki sonucu gösterecektir. Bu, yerel makinenizden herhangi bir dosya yüklemenize yardımcı olacaktır.

File Upload

Select a file to upload −


JSP komut dosyanız düzgün çalışıyorsa, dosyanızın şuraya yüklenmesi gerekir: c:\apache-tomcat5.5.29\webapps\data\ dizin.

Bu bölümde, JSP'de verilerin nasıl ele alınacağını tartışacağız. JSP kullanmanın en önemli avantajlarından biri, çekirdek Java'da bulunan tüm yöntemleri kullanabilmenizdir. Sizi içinden geçireceğizDate mevcut sınıf java.utilpaket; bu sınıf, geçerli tarih ve saati kapsar.

Date sınıfı iki yapıcıyı destekler. İlk kurucu, nesneyi geçerli tarih ve saatle başlatır.

Date( )

Aşağıdaki kurucu, 1 Ocak 1970 gece yarısından bu yana geçen milisaniye sayısına eşit olan bir bağımsız değişkeni kabul eder.

Date(long millisec)

Bir Date nesnesine sahip olduğunuzda, tarihlerle oynamak için aşağıdaki destek yöntemlerinden herhangi birini çağırabilirsiniz -

S.No. Yöntemler ve Açıklama
1

boolean after(Date date)

Çağrılan Date nesnesi tarihe göre belirtilenden daha sonraki bir tarih içeriyorsa true, aksi takdirde false döndürür.

2

boolean before(Date date)

Çağrılan Date nesnesi, tarihe göre belirtilenden daha eski bir tarih içeriyorsa true, aksi takdirde false döndürür.

3

Object clone( )

Çağrılan Date nesnesini çoğaltır.

4

int compareTo(Date date)

Çağrılan nesnenin değerini tarihin değeriyle karşılaştırır. Değerler eşitse 0 döndürür. Çağrılan nesne tarihten önceyse negatif bir değer döndürür. Çağrılan nesne tarihten sonraysa pozitif bir değer döndürür.

5

int compareTo(Object obj)

Obj, Date sınıfındaysa, ComparTo (Date) ile aynı şekilde çalışır. Aksi takdirde, bir ClassCastException oluşturur.

6

boolean equals(Object date)

Çağrılan Date nesnesi, tarihe göre belirtilenle aynı saat ve tarihi içeriyorsa true, aksi takdirde false döndürür.

7

long getTime( )

1 Ocak 1970'ten bu yana geçen milisaniye sayısını döndürür.

8

int hashCode( )

Çağrılan nesne için bir karma kod döndürür.

9

void setTime(long time)

Saati ve tarihi, 1 Ocak 1970 gece yarısından milisaniye cinsinden geçen zamanı temsil eden, zamana göre belirtilen şekilde ayarlar

10

String toString( )

Çağrılan Date nesnesini bir dizeye dönüştürür ve sonucu döndürür.

Güncel Tarih ve Saati Alma

JSP programı ile güncel tarih ve saati almak çok kolaydır. Basit bir Date nesnesi kullanabilirsiniz.toString() geçerli tarihi ve saati aşağıdaki gibi yazdırma yöntemi -

<%@ page import = "java.io.*,java.util.*, javax.servlet.*" %>

<html>
   <head>
      <title>Display Current Date & Time</title>
   </head>
   
   <body>
      <center>
         <h1>Display Current Date & Time</h1>
      </center>
      <%
         Date date = new Date();
         out.print( "<h2 align = \"center\">" +date.toString()+"</h2>");
      %>
   </body>
</html>

Şimdi kodu içeride tutalım CurrentDate.jsp ve sonra bu JSP'yi URL'yi kullanarak çağırın http://localhost:8080/CurrentDate.jsp. Aşağıdaki sonucu alacaksınız -

Display Current Date & Time

Mon Jun 21 21:46:49 GMT+04:00 2010

Sayfayı şununla yenileyin: URL http://localhost:8080/CurrentDate.jsp. Her yenilediğinizde saniyeler içinde fark bulacaksınız.

Tarih Karşılaştırması

Önceki bölümlerde tartışıldığı gibi, mevcut tüm Java yöntemlerini JSP komut dosyalarınızda kullanabilirsiniz. İki tarihi karşılaştırmanız gerekirse, aşağıdaki yöntemleri göz önünde bulundurun -

  • Kullanabilirsiniz getTime( ) Her iki nesne için 1 Ocak 1970 gece yarısından bu yana geçen milisaniye sayısını elde etmek ve ardından bu iki değeri karşılaştırmak için yöntem.

  • Yöntemleri kullanabilirsiniz before( ), after( ), ve equals( )çünkü ayın 12'si 18'inden önce gelir; Örneğin,new Date(99, 2, 12).before(new Date (99, 2, 18)) true döndürür.

  • Kullanabilirsiniz compareTo( )yöntem; bu yöntem,Comparable interface ve Tarihe göre uygulanmaktadır.

SimpleDateFormat kullanarak Tarih Biçimlendirme

SimpleDateFormat, tarihleri ​​yerel ayara duyarlı bir şekilde biçimlendirmek ve ayrıştırmak için somut bir sınıftır. SimpleDateFormat, tarih-saat biçimlendirmesi için herhangi bir kullanıcı tanımlı kalıp seçerek başlamanıza olanak tanır.

Yukarıdaki örneği aşağıdaki gibi değiştirelim -

<%@ page import = "java.io.*,java.util.*" %>
<%@ page import = "javax.servlet.*,java.text.*" %>

<html>
   <head>
      <title>Display Current Date & Time</title>
   </head>
   
   <body>
      <center>
         <h1>Display Current Date & Time</h1>
      </center>
      <%
         Date dNow = new Date( );
         SimpleDateFormat ft = 
         new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz");
         out.print( "<h2 align=\"center\">" + ft.format(dNow) + "</h2>");
      %>
   </body>
</html>

Yukarıdaki sunucu uygulamasını bir kez daha derleyin ve ardından bu sunucu uygulamasını URL'yi kullanarak çağırın. http://localhost:8080/CurrentDate. Aşağıdaki sonucu alacaksınız -

Display Current Date & Time

Mon 2010.06.21 at 10:06:44 PM GMT+04:00

Basit Tarih Biçimi Biçim Kodları

Saat biçimini belirtmek için bir zaman modeli dizesi kullanın. Bu modelde, tüm ASCII harfleri aşağıdaki gibi tanımlanan model harfleri olarak ayrılmıştır -

Karakter Açıklama Misal
G Çağ belirleyici AD
y Dört basamaklı yıl 2001
M Yıldaki ay Temmuz veya 07
d Aydaki gün 0
h ÖÖ / ÖS olarak saat (1 ~ 12) 2
H Gün içindeki saat (0 ~ 23) 22
m Saat cinsinden dakika 30
s Dakikada ikinci 55
S Milisaniye 234
E Hafta içi gün Salı
D Yıldaki gün 360
F Ay içinde haftanın günü 2 (Temmuz'da ikinci Çarşamba)
w Yıldaki hafta 40
W Aydaki hafta
a AM / PM işaretçisi ÖS
k Gün içindeki saat (1 ~ 24) 24
K ÖÖ / ÖS olarak saat (0 ~ 11) 0
z Saat dilimi Doğu standart zamanı
' Metin için kaçış Sınırlayıcı
" Tek alıntı '

Tarihi değiştirmeye yönelik sürekli mevcut yöntemlerin tam listesi için standart Java belgelerine bakabilirsiniz.

Bu bölümde, JSP ile sayfa yeniden yönlendirmeyi tartışacağız. Sayfa yönlendirme genellikle bir belge yeni bir konuma taşındığında kullanılır ve istemciyi bu yeni konuma göndermemiz gerekir. Bunun nedeni yük dengeleme veya basit rastgele seçim olabilir.

Bir isteği başka bir sayfaya yönlendirmenin en basit yolu, sendRedirect()yanıt nesnesi yöntemi. Bu yöntemin imzası aşağıdadır -

public void response.sendRedirect(String location)
throws IOException

Bu yöntem, yanıtı durum kodu ve yeni sayfa konumu ile birlikte tarayıcıya geri gönderir. Ayrıca şunu da kullanabilirsiniz:setStatus() ve setHeader() aynı yeniden yönlendirme örneğini elde etmek için yöntemleri birlikte -

....
String site = "http://www.newpage.com" ;
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site); 
....

Misal

Bu örnek, bir JSP'nin başka bir konuma sayfa yeniden yönlendirmeyi nasıl gerçekleştirdiğini gösterir -

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Page Redirection</title>
   </head>
   
   <body>
      <center>
         <h1>Page Redirection</h1>
      </center>
      <%
         // New location to be redirected
         String site = new String("http://www.photofuntoos.com");
         response.setStatus(response.SC_MOVED_TEMPORARILY);
         response.setHeader("Location", site); 
      %>
   </body>
</html>

Şimdi yukarıdaki kodu PageRedirect.jsp içine koyalım ve bu JSP'yi URL'yi kullanarak arayalım http://localhost:8080/PageRedirect.jsp. Bu sizi verilen URL'ye götürürhttp://www.photofuntoos.com.

Bu bölümde, JSP'deki Hits Counter'ı tartışacağız. Bir isabet sayacı, web sitenizin belirli bir sayfasındaki ziyaretlerin sayısını size söyler. Genellikle, insanların ilk olarak ana sayfanıza geldiğini varsayarak, index.jsp sayfanıza bir isabet sayacı eklersiniz.

Bir isabet sayacı uygulamak için Application Implicit nesnesini ve ilişkili yöntemleri kullanabilirsiniz. getAttribute() ve setAttribute().

Bu nesne, tüm yaşam döngüsü boyunca JSP sayfasının bir temsilidir. Bu nesne, JSP sayfası başlatıldığında oluşturulur ve JSP sayfası tarafından kaldırıldığında kaldırılır.jspDestroy() yöntem.

Aşağıda, uygulama düzeyinde bir değişken ayarlamak için sözdizimi verilmiştir -

application.setAttribute(String Key, Object Value);

Bir hit counter değişkeni ayarlamak ve aynı değişkeni sıfırlamak için yukarıdaki yöntemi kullanabilirsiniz. Aşağıdaki yöntem, önceki yöntemle ayarlanan değişkeni okuma yöntemidir -

application.getAttribute(String Key);

Bir kullanıcı sayfanıza her eriştiğinde, isabet sayacının mevcut değerini okuyabilir ve bir artırabilir ve ileride kullanmak üzere tekrar ayarlayabilirsiniz.

Misal

Bu örnek, belirli bir sayfadaki toplam isabet sayısını saymak için JSP'yi nasıl kullanabileceğinizi gösterir. Web sitenizin toplam ziyaret sayısını saymak istiyorsanız, aynı kodu tüm JSP sayfalarına dahil etmeniz gerekecektir.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Application object in JSP</title>
   </head>
   
   <body>
      <%
         Integer hitsCount = (Integer)application.getAttribute("hitCounter");
         if( hitsCount ==null || hitsCount == 0 ) {
            /* First visit */
            out.println("Welcome to my website!");
            hitsCount = 1;
         } else {
            /* return visit */
            out.println("Welcome back to my website!");
            hitsCount += 1;
         }
         application.setAttribute("hitCounter", hitsCount);
      %>
      <center>
         <p>Total number of visits: <%= hitsCount%></p>
      </center>
   
   </body>
</html>

Şimdi yukarıdaki kodu yerine koyalım main.jsp ve bu JSP'yi URL'yi kullanarak arayın http://localhost:8080/main.jsp. Bu, sayfayı yeniledikçe ve yenilediğinizde artan isabet sayacı değerini gösterecektir. Sayfaya farklı tarayıcılar kullanarak erişmeyi deneyebilirsiniz ve isabet sayacının her vuruşta artmaya devam edeceğini ve sonucu aşağıdaki gibi alacağınızı göreceksiniz -

Welcome back to my website!

Total number of visits: 12

Sayaç Sıfırlamaları

Uygulamanızı, yani web sunucunuzu yeniden başlattığınızda, bu uygulama değişkeninizi sıfırlar ve sayacınız sıfırlanır. Bu kaybı önlemek için aşağıdaki noktaları göz önünde bulundurun -

  • Tek sayılı bir veritabanı tablosu tanımlayın, hitcount diyelim. Sıfır değeri atayın.

  • Her vuruşta, hitcount'un değerini öğrenmek için tabloyu okuyun.

  • Hitcount değerini bir artırın ve tabloyu yeni değerle güncelleyin.

  • Yeni hitcount değerini toplam sayfa isabet sayısı olarak görüntüleyin.

  • Tüm sayfalar için isabetleri saymak istiyorsanız, tüm sayfalar için yukarıdaki mantığı uygulayın.

Bu bölümde, JSP'de Otomatik Yenilemeyi tartışacağız. Canlı oyun skorunu veya borsa durumunu veya döviz kuru oranını gösteren bir web sayfasını düşünün. Tüm bu tür sayfalar için, tarayıcınızda yenile veya yeniden yükle düğmesini kullanarak Web sayfanızı düzenli olarak yenilemeniz gerekir.

JSP, belirli bir aralıktan sonra otomatik olarak yenilenecek şekilde bir web sayfası oluşturabileceğiniz bir mekanizma sağlayarak bu işi kolaylaştırır.

Bir Web sayfasını yenilemenin en basit yolu, setIntHeader()yanıt nesnesinin yöntemi. Bu yöntemin imzası aşağıdadır -

public void setIntHeader(String header, int headerValue)

Bu yöntem, saniye cinsinden zaman aralığını gösteren bir tamsayı değeriyle birlikte tarayıcıya "Yenile" başlığını geri gönderir.

Otomatik Sayfa Yenileme Örneği

Aşağıdaki örnekte, kullanacağız setIntHeader() ayarlama yöntemi Refreshbaşlık. Bu, dijital bir saati simüle etmeye yardımcı olacaktır -

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Auto Refresh Header Example</title>
   </head>
   
   <body>
      <center>
         <h2>Auto Refresh Header Example</h2>
         <%
            // Set refresh, autoload time as 5 seconds
            response.setIntHeader("Refresh", 5);
            
            // Get current time
            Calendar calendar = new GregorianCalendar();
            String am_pm;
            
            int hour = calendar.get(Calendar.HOUR);
            int minute = calendar.get(Calendar.MINUTE);
            int second = calendar.get(Calendar.SECOND);
            
            if(calendar.get(Calendar.AM_PM) == 0)
               am_pm = "AM";
            else
               am_pm = "PM";
            String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
            out.println("Crrent Time: " + CT + "\n");
         %>
      </center>
   
   </body>
</html>

Şimdi yukarıdaki kodu yerleştirin main.jspve erişmeye çalışın. Bu, aşağıdaki gibi her 5 saniyede bir mevcut sistem zamanını gösterecektir. JSP'yi çalıştırın ve sonucu görmek için bekleyin -

Auto Refresh Header Example

Current Time is: 9:44:50 PM

Bu bölümde, JSP kullanarak e-postaların nasıl gönderileceğini tartışacağız. JSP kullanarak e-posta göndermek için,JavaMail API ve Java Activation Framework (JAF) makinenize kurulur.

  • JavaMail'in en son sürümünü (Sürüm 1.2) Java'nın standart web sitesinden indirebilirsiniz .

  • JavaBeans Activation Framework JAF'ın (Sürüm 1.0.2) en son sürümünü Java'nın standart web sitesinden indirebilirsiniz .

Yeni oluşturulan üst düzey dizinlerde bu dosyaları indirin ve açın. Her iki uygulama için bir dizi jar dosyası bulacaksınız. Eklemeniz gerekiyormail.jar ve activation.jar CLASSPATH dosyanızdaki dosyalar.

Basit Bir E-posta Gönderin

İşte makinenizden basit bir e-posta göndermenin bir örneği. Senin olduğu varsayılmaktadırlocalhostİnternete bağlı ve bir e-posta gönderebilecek kadar yetenekli. Java Email API paketindeki ve JAF paketindeki tüm jar dosyalarının CLASSPATH'da mevcut olduğundan emin olun.

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);
      
      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));
      
      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO,
                               new InternetAddress(to));
      // Set Subject: header field
      message.setSubject("This is the Subject Line!");
      
      // Now set the actual message
      message.setText("This is actual message");
      
      // Send message
      Transport.send(message);
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send Email using JSP</title>
   </head>
   
   <body>
      <center>
         <h1>Send Email using JSP</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Result: " + result + "\n");
         %>
      </p>
   </body>
</html>

Şimdi yukarıdaki kodu yerine koyalım SendEmail.jsp dosyasını açın ve URL'yi kullanarak bu JSP'yi çağırın http://localhost:8080/SendEmail.jsp. Bu, verilen e-posta kimliğine bir e-posta göndermeye yardımcı olacaktır[email protected]. Aşağıdaki yanıtı alacaksınız -

Send Email using JSP

Result: Sent message successfully....

Birden fazla alıcıya bir e-posta göndermek istiyorsanız, birden çok e-posta kimliği belirtmek için aşağıdaki yöntemleri kullanın -

void addRecipients(Message.RecipientType type, Address[] addresses)
throws MessagingException

İşte parametrelerin açıklaması -

  • type- Bu TO, CC veya BCC olarak ayarlanacaktır. Burada CC, Carbon Copy'yi ve BCC, Black Carbon Copy'yi temsil eder. Örnek Message.RecipientType.TO

  • addresses- Bu, e-posta kimliği dizisidir. E-posta kimliklerini belirlerken InternetAddress () yöntemini kullanmanız gerekir

HTML E-posta Gönderin

İşte makinenizden bir HTML e-postası göndermenin bir örneği. Senin olduğu varsayılmaktadırlocalhostİnternete bağlı ve bir e-posta gönderebilecek kadar yetenekli. İçindeki tüm jar dosyalarınınJava Email API package ve JAF package CLASSPATH'da mevcuttur.

Bu örnek bir öncekine çok benzer, tek farkı burada setContent() ikinci argümanı olan içeriği ayarlama yöntemi "text/html" HTML içeriğinin mesaja dahil edildiğini belirtmek için.

Bu örneği kullanarak, istediğiniz kadar büyük bir HTML içeriği gönderebilirsiniz.

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);
      
      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));
      
      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
      
      // Set Subject: header field
      message.setSubject("This is the Subject Line!");
     
      // Send the actual HTML message, as big as you like
      message.setContent("<h1>This is actual message</h1>", "text/html" );
      
      // Send message
      Transport.send(message);
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send HTML Email using JSP</title>
   </head>

   <body>
      <center>
         <h1>Send Email using JSP</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Result: " + result + "\n");
         %>
      </p>
   </body>
</html>

Verilen bir e-posta kimliğine HTML mesajı göndermek için şimdi yukarıdaki JSP'yi kullanalım.

Eki E-postayla Gönder

Aşağıda, makinenizden ekli bir e-posta göndermeye bir örnek verilmiştir -

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);

      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));

      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));

      // Set Subject: header field
      message.setSubject("This is the Subject Line!");

      // Create the message part 
      BodyPart messageBodyPart = new MimeBodyPart();

      // Fill the message
      messageBodyPart.setText("This is message body");
      
      // Create a multipart message
      Multipart multipart = new MimeMultipart();

      // Set text message part
      multipart.addBodyPart(messageBodyPart);

      // Part two is attachment
      messageBodyPart = new MimeBodyPart();
      
      String filename = "file.txt";
      DataSource source = new FileDataSource(filename);
      messageBodyPart.setDataHandler(new DataHandler(source));
      messageBodyPart.setFileName(filename);
      multipart.addBodyPart(messageBodyPart);

      // Send the complete message parts
      message.setContent(multipart );

      // Send message
      Transport.send(message);
      String title = "Send Email";
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send Attachment Email using JSP</title>
   </head>
   
   <body>
      <center>
         <h1>Send Attachment Email using JSP</h1>
      </center>
      
      <p align = "center">
         <%out.println("Result: " + result + "\n");%>
      </p>
   </body>
</html>

Verilen bir e-posta kimliğindeki bir mesajla birlikte bir dosyayı ek olarak göndermek için yukarıdaki JSP'yi çalıştıralım.

Kullanıcı Kimlik Doğrulama Bölümü

Kimlik doğrulama amacıyla e-posta sunucusuna kullanıcı kimliği ve Parola sağlamanız gerekiyorsa, bu özellikleri aşağıdaki gibi ayarlayabilirsiniz -

props.setProperty("mail.user", "myuser");
props.setProperty("mail.password", "mypwd");

E-posta gönderme mekanizmasının geri kalanı yukarıda açıklandığı gibi kalacaktır.

E-posta Göndermek İçin Formları Kullanma

E-posta parametrelerini kabul etmek için HTML formunu kullanabilir ve ardından request tüm bilgileri aşağıdaki gibi almak için nesne -

String to = request.getParameter("to");
String from = request.getParameter("from");
String subject = request.getParameter("subject");
String messageText = request.getParameter("body");

Tüm bilgilere sahip olduğunuzda, e-posta göndermek için yukarıda belirtilen programları kullanabilirsiniz.

Bu bölümde, JSP'deki farklı etiketleri anlayacağız. JavaServer Sayfaları Standart Etiket Kitaplığı (JSTL), birçok JSP uygulamasında ortak olan temel işlevleri kapsayan kullanışlı JSP etiketleri koleksiyonudur.

JSTL, yineleme ve koşul ifadeleri, XML belgelerinin işlenmesine yönelik etiketler, uluslararasılaştırma etiketleri ve SQL etiketleri gibi ortak, yapısal görevleri destekler. Ayrıca mevcut özel etiketleri JSTL etiketleriyle entegre etmek için bir çerçeve sağlar.

JSTL Kitaplığını yükleyin

JSP ile çalışmaya başlamak için önce JSTL kitaplığını kurmanız gerekir. Apache Tomcat kapsayıcısını kullanıyorsanız, şu iki adımı izleyin -

Step 1- Apache Standard Taglib'den ikili dağıtımı indirin ve sıkıştırılmış dosyayı açın.

Step 2 - Standart Taglib'i kendi Jakarta Taglibs distribution, dağıtımın 'lib' dizinindeki JAR dosyalarını uygulamanızın webapps\ROOT\WEB-INF\lib dizin.

Kitaplıklardan herhangi birini kullanmak için, kitaplığı kullanan her JSP'nin üstüne bir <taglib> yönergesi eklemelisiniz.

JSTL Etiketlerinin Sınıflandırılması

JSTL etiketleri, işlevlerine göre, bir JSP sayfası oluştururken kullanılabilecek aşağıdaki JSTL etiket kitaplığı gruplarına sınıflandırılabilir -

  • Core Tags

  • Formatting tags

  • SQL tags

  • XML tags

  • JSTL Functions

Çekirdek Etiketler

Çekirdek etiket grubu, en yaygın kullanılan JSTL etiketleridir. JSTL Core kitaplığını JSP'nize dahil etmek için sözdizimi aşağıdadır -

<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>

Aşağıdaki tablo temel JSTL Etiketlerini listeler -

S.No. Etiket ve Açıklama
1

<% = ...> gibi, ancak ifadeler için.

2

Bir ifade değerlendirmesinin sonucunu bir 'scope'

3

Kaldırır scoped variable (belirtilmişse, belirli bir kapsamdan).

4

Herhangi birini yakalar Throwable vücudunda meydana gelir ve isteğe bağlı olarak açığa çıkarır.

5

Sağlanan koşulun doğru olup olmadığını değerlendiren basit koşullu etiket.

6

Birbirini dışlayan koşullu işlemler için bir bağlam oluşturan basit koşullu etiket <when> ve <otherwise>.

7

Alt etiketi <choose> durumu değerlendirilirse vücudunu içerir 'true'.

8

Alt etiketi <choose> takip eden <when> etiketler ve yalnızca önceki koşulların tümü değerlendirilirse çalışır 'false'.

9

Mutlak veya göreceli bir URL alır ve içeriğini sayfaya, 'var'veya içindeki bir Okuyucu 'varReader'.

10

Birçok farklı koleksiyon türünü kabul eden ve alt küme oluşturma ve diğer işlevleri destekleyen temel yineleme etiketi.

11

Sağlanan sınırlayıcılarla ayrılmış belirteçleri yineler.

12

İçeren bir 'import' etiketinin URL'si.

13

Yeni bir URL'ye yönlendirir.

14

İsteğe bağlı sorgu parametreleriyle bir URL oluşturur

Etiketleri Biçimlendirme

JSTL biçimlendirme etiketleri, uluslararasılaştırılmış Web Siteleri için metni, tarihi, saati ve sayıları biçimlendirmek ve görüntülemek için kullanılır. JSP'nize Biçimlendirme kitaplığını dahil etmek için sözdizimi aşağıdadır -

<%@ taglib prefix = "fmt" uri = "http://java.sun.com/jsp/jstl/fmt" %>

Aşağıdaki tablo Biçimlendirme JSTL Etiketlerini listeler -

S.No. Etiket ve Açıklama
1

Sayısal değeri belirli bir hassasiyet veya formatla oluşturmak için.

2

Bir sayının, para biriminin veya yüzdesinin dize temsilini çözümler.

3

Verilen stilleri ve kalıbı kullanarak bir tarih ve / veya saati biçimlendirir.

4

Bir tarihin ve / veya saatin dize gösterimini çözümler

5

Etiket gövdesi tarafından kullanılacak bir kaynak paketini yükler.

6

Verilen yerel ayarı yerel yapılandırma değişkeninde depolar.

7

Bir kaynak paketini yükler ve adlandırılmış kapsamlı değişkende veya paket yapılandırma değişkeninde depolar.

8

Gövdesinde yuvalanmış herhangi bir saat biçimlendirme veya ayrıştırma eylemi için saat dilimini belirtir.

9

Verilen saat dilimini saat dilimi yapılandırma değişkeninde depolar

10

Uluslararası bir mesaj görüntüler.

11

İstek karakter kodlamasını ayarlar

SQL Etiketleri

JSTL SQL etiket kitaplığı, aşağıdaki gibi ilişkisel veritabanları (RDBMS'ler) ile etkileşim için etiketler sağlar. Oracle, mySQLveya Microsoft SQL Server.

JSP'nize JSTL SQL kitaplığını dahil etmek için sözdizimi aşağıdadır -

<%@ taglib prefix = "sql" uri = "http://java.sun.com/jsp/jstl/sql" %>

Aşağıdaki tablo SQL JSTL Etiketlerini listeler -

S.No. Etiket ve Açıklama
1

Yalnızca prototip oluşturmaya uygun basit bir Veri Kaynağı oluşturur

2

Gövdesi içinde veya sql özelliği ile tanımlanan SQL sorgusunu çalıştırır.

3

Gövdesinde veya sql özniteliğiyle tanımlanan SQL güncellemesini yürütür.

4

SQL ifadesindeki bir parametreyi belirtilen değere ayarlar.

5

SQL deyimindeki bir parametreyi belirtilen java.util.Date değerine ayarlar.

6

Tüm ifadeleri tek bir işlem olarak yürütmek için ayarlanmış, paylaşılan bir Bağlantı ile iç içe geçmiş veritabanı eylem öğeleri sağlar.

XML etiketleri

JSTL XML etiketleri, XML belgelerinin oluşturulması ve işlenmesi için JSP merkezli bir yol sağlar. JSP'nize JSTL XML kitaplığını dahil etmek için sözdizimi aşağıdadır.

JSTL XML etiket kitaplığı, XML verileriyle etkileşim için özel etiketlere sahiptir. Bu, XML'in ayrıştırılmasını, XML verilerinin dönüştürülmesini ve XPath ifadelerine dayalı akış denetimini içerir.

<%@ taglib prefix = "x" 
   uri = "http://java.sun.com/jsp/jstl/xml" %>

Örneklere geçmeden önce, aşağıdaki iki XML ve XPath ile ilgili kitaplığı kopyalamanız gerekecek. <Tomcat Installation Directory>\lib -

  • XercesImpl.jar - adresinden indirin https://www.apache.org/dist/xerces/j/

  • xalan.jar - adresinden indirin https://xml.apache.org/xalan-j/index.html

XML JSTL Etiketlerinin listesi aşağıdadır -

S.No. Etiket ve Açıklama
1

<% = ...> gibi, ancak XPath ifadeleri için.

2

Bir öznitelik yoluyla veya etiket gövdesinde belirtilen XML verilerini ayrıştırmak için kullanılır.

3

Değişkeni bir XPath ifadesinin değerine ayarlar.

4

Bir test XPath ifadesini değerlendirir ve doğruysa gövdesini işler. Test koşulu yanlışsa, gövde dikkate alınmaz.

5

Bir XML belgesindeki düğümler üzerinden döngü yapmak için.

6

Birbirini dışlayan koşullu işlemler için bir bağlam oluşturan basit koşullu etiket <when> ve <otherwise> etiketleri.

7

Alt etiketi <choose> ifadesi 'doğru' olarak değerlendirilirse gövdesini içerir.

8

Alt etiketi <choose> takip eden <when> etiketler ve yalnızca önceki koşulların tümü 'yanlış' olarak değerlendirilirse çalışır.

9

XML belgesine bir XSL dönüşümü uygular

10

İle birlikte kullanılır transform XSLT stil sayfasında bir parametre ayarlamak için etiket

JSTL İşlevleri

JSTL, çoğu ortak dize işleme işlevleri olan bir dizi standart işlev içerir. JSP'nize JSTL İşlevleri kitaplığını dahil etmek için sözdizimi aşağıdadır -

<%@ taglib prefix = "fn" 
   uri = "http://java.sun.com/jsp/jstl/functions" %>

Aşağıdaki tablo çeşitli JSTL İşlevlerini listelemektedir -

S.No. İşlev ve Açıklama
1 fn: içerir ()

Bir giriş dizesinin belirtilen alt dizeyi içerip içermediğini test eder.

2 fn: containsIgnoreCase ()

Bir giriş dizesinin, büyük / küçük harf duyarlı bir şekilde belirtilen alt dizeyi içerip içermediğini test eder.

3 fn :endsWith ()

Bir giriş dizesinin belirtilen sonekle bitip bitmediğini test eder.

4 fn: escapeXml ()

XML biçimlendirmesi olarak yorumlanabilen karakterlerden kaçar.

5 fn: indexOf ()

Belirtilen bir alt dizenin ilk oluşumunun bir dizesini içeren dizini döndürür.

6 fn: katılmak ()

Bir dizinin tüm öğelerini bir dizede birleştirir.

7 fn: uzunluk ()

Bir koleksiyondaki öğe sayısını veya bir dizedeki karakter sayısını döndürür.

8 fn: replace ()

Bir girdi dizesindeki tüm oluşumların belirli bir dizeyle değiştirilmesinden kaynaklanan bir dize döndürür.

9 fn: bölme ()

Bir dizeyi bir dizi alt dizeye böler.

10 fn: startsWith ()

Bir giriş dizesinin belirtilen önek ile başlayıp başlamadığını test eder.

11 fn: substring ()

Bir dizenin alt kümesini döndürür.

12 fn: substringAfter ()

Belirli bir alt dizeyi izleyen bir dizenin alt kümesini döndürür.

13 fn: substringBefore ()

Belirli bir alt dizeden önce bir dizenin alt kümesini döndürür.

14 fn: toLowerCase ()

Bir dizenin tüm karakterlerini küçük harfe dönüştürür.

15 fn: toUpperCase ()

Bir dizenin tüm karakterlerini büyük harfe dönüştürür.

16 fn: trim ()

Bir dizenin her iki ucundaki beyaz boşlukları kaldırır.

Bu bölümde, JSP ile veritabanına nasıl erişileceğini tartışacağız. JDBC uygulamasının nasıl çalıştığını iyi anladığınızı varsayıyoruz. Bir JSP aracılığıyla veritabanı erişimine başlamadan önce, bir veritabanıyla birlikte uygun JDBC ortamı kurulumuna sahip olduğunuzdan emin olun.

JDBC ve ortam kurulumunu kullanarak veritabanına nasıl erişileceğine ilişkin daha fazla ayrıntı için, JDBC Eğitimimizi inceleyebilirsiniz .

Temel kavramla başlamak için, bir tablo oluşturalım ve bu tabloda aşağıdaki gibi birkaç kayıt oluşturalım -

Tablo Oluştur

Oluşturmak için Employees EMP veritabanındaki tablo için aşağıdaki adımları kullanın -

Aşama 1

Bir Command Prompt ve aşağıdaki gibi kurulum dizinine geçin -

C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>

Adım 2

Veritabanına aşağıdaki şekilde giriş yapın -

C:\Program Files\MySQL\bin>mysql -u root -p
Enter password: ********
mysql>

Aşama 3

Oluştur Employee tablo TEST aşağıdaki gibi veritabanı - -

mysql> use TEST;
mysql> create table Employees
   (
      id int not null,
      age int not null,
      first varchar (255),
      last varchar (255)
   );
Query OK, 0 rows affected (0.08 sec)
mysql>

Veri Kayıtları Oluşturun

Şimdi şurada birkaç kayıt oluşturalım: Employee aşağıdaki tablo - -

mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
Query OK, 1 row affected (0.05 sec)
 
mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
Query OK, 1 row affected (0.00 sec)
 
mysql>

SELECT İşlemi

Aşağıdaki örnek, SQL SELECT JSP programlamada JTSL kullanan ifade -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>SELECT Operation</title>
   </head>

   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root"  password = "pass123"/>
 
      <sql:query dataSource = "${snapshot}" var = "result">
         SELECT * from Employees;
      </sql:query>
 
      <table border = "1" width = "100%">
         <tr>
            <th>Emp ID</th>
            <th>First Name</th>
            <th>Last Name</th>
            <th>Age</th>
         </tr>
         
         <c:forEach var = "row" items = "${result.rows}"> <tr> <td><c:out value = "${row.id}"/></td>
               <td><c:out value = "${row.first}"/></td> <td><c:out value = "${row.last}"/></td>
               <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Yukarıdaki JSP'ye erişin, aşağıdaki sonuç görüntülenecektir -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30
103 Sumit Mittal 28

INSERT İşlemi

Aşağıdaki örnek, JSP programlamada JTSL kullanarak SQL INSERT ifadesini nasıl çalıştırabileceğimizi gösterir -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>JINSERT Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root"  password = "pass123"/>
         <sql:update dataSource = "${snapshot}" var = "result">
         INSERT INTO Employees VALUES (104, 2, 'Nuha', 'Ali');
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Yukarıdaki JSP'ye erişin, aşağıdaki sonuç görüntülenecektir -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30
103 Sumit Mittal 28
104 Nuha Ali 2

DELETE İşlemi

Aşağıdaki örnek, SQL DELETE JSP programlamada JTSL kullanan ifade -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>DELETE Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root" password = "pass123"/>
 
      <c:set var = "empId" value = "103"/>
 
      <sql:update dataSource = "${snapshot}" var = "count"> DELETE FROM Employees WHERE Id = ? <sql:param value = "${empId}" />
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Yukarıdaki JSP'ye erişin, aşağıdaki sonuç görüntülenecektir -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30

GÜNCELLEME İşlemi

Aşağıdaki örnek, SQL UPDATE JSP programlamada JTSL kullanan ifade -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri = "http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri = "http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>DELETE Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root" password = "pass123"/>
 
      <c:set var = "empId" value = "102"/>
 
      <sql:update dataSource = "${snapshot}" var = "count"> UPDATE Employees SET WHERE last = 'Ali' <sql:param value = "${empId}" />
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Yukarıdaki JSP'ye erişin, aşağıdaki sonuç görüntülenecektir -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Ali 30

XML verilerini HTTP yoluyla gönderdiğinizde, gelen ve giden XML belgelerini işlemek için JSP'yi kullanmak mantıklıdır; örneğin, RSS belgeleri. XML belgesi yalnızca bir metin demeti olduğundan, JSP aracılığıyla bir tane oluşturmak, bir HTML belgesi oluşturmaktan çok daha kolaydır.

JSP'den XML gönderme

XML içeriğini HTML gönderdiğiniz gibi JSP'leri kullanarak gönderebilirsiniz. Tek fark, sayfanızın içerik türünü text / xml olarak ayarlamanız gerektiğidir. İçerik türünü ayarlamak için şunu kullanın:<%@page%> etiket, bunun gibi -

<%@ page contentType = "text/xml" %>

Aşağıdaki örnek, XML içeriğinin tarayıcıya nasıl gönderileceğini gösterecektir -

<%@ page contentType = "text/xml" %>

<books>
   <book>
      <name>Padam History</name>
      <author>ZARA</author>
      <price>100</price>
   </book>
</books>

Yukarıdaki XML'in belge ağacı sunumunu görmek için farklı tarayıcılar kullanarak yukarıdaki XML'e erişin.

JSP'de XML işleniyor

JSP kullanarak XML işlemeye devam etmeden önce, aşağıdaki iki XML ve XPath ile ilgili kitaplığı sitenize kopyalamanız gerekir. <Tomcat Installation Directory>\lib -

  • XercesImpl.jar - adresinden indirin https://www.apache.org/dist/xerces/j/

  • xalan.jar - adresinden indirin https://xml.apache.org/xalan-j/index.html

Şu içeriği books.xml dosyasına koyalım -

<books>
   <book>
      <name>Padam History</name>
      <author>ZARA</author>
      <price>100</price>
   </book>
   
   <book>
      <name>Great Mistry</name>
      <author>NUHA</author>
      <price>2000</price>
   </book>
</books>

Takip etmeyi dene main.jsp, aynı dizinde tutulur -

<%@ taglib prefix = "c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix = "x" uri="http://java.sun.com/jsp/jstl/xml" %>
 
<html>
   <head>
      <title>JSTL x:parse Tags</title>
   </head>

   <body>
      <h3>Books Info:</h3>
      <c:import var = "bookInfo" url="http://localhost:8080/books.xml"/>
 
      <x:parse xml = "${bookInfo}" var = "output"/> <b>The title of the first book is</b>: <x:out select = "$output/books/book[1]/name" />
      <br>
      
      <b>The price of the second book</b>: 
      <x:out select = "$output/books/book[2]/price" />
   </body>
</html>

Yukarıdaki JSP'ye şunu kullanarak erişin: http://localhost:8080/main.jsp, aşağıdaki sonuç görüntülenecektir -

Books Info:

The title of the first book is:Padam History The price of the second book: 2000

XML'i JSP ile biçimlendirme

Aşağıdaki XSLT stil sayfasını düşünün style.xsl -

<?xml version = "1.0"?>
<xsl:stylesheet xmlns:xsl = "http://www.w3.org/1999/XSL/Transform" 
   version = "1.0">
 
   <xsl:output method = "html" indent = "yes"/>
   <xsl:template match = "/">
      <html>
         <body>
            <xsl:apply-templates/>
         </body>
      </html>
   </xsl:template>
    
   <xsl:template match = "books">
      <table border = "1" width = "100%">
         <xsl:for-each select = "book">
            <tr>
               <td>
                  <i><xsl:value-of select = "name"/></i>
               </td>
               
               <td>
                  <xsl:value-of select = "author"/>
               </td>
               
               <td>
                  <xsl:value-of select = "price"/>
               </td>
            </tr>
         </xsl:for-each>
      </table>
   
   </xsl:template>
</xsl:stylesheet>

Şimdi aşağıdaki JSP dosyasını düşünün -

<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix = "x" uri = "http://java.sun.com/jsp/jstl/xml" %>
 
<html>
   <head>
      <title>JSTL x:transform Tags</title>
   </head>
   
   <body>
      <h3>Books Info:</h3>
      <c:set var = "xmltext">
         <books>
            <book>
               <name>Padam History</name>
               <author>ZARA</author>
               <price>100</price>
            </book>
            
            <book>
               <name>Great Mistry</name>
               <author>NUHA</author>
               <price>2000</price>
            </book>
         </books>
      </c:set>
 
      <c:import url = "http://localhost:8080/style.xsl" var = "xslt"/>
      <x:transform xml = "${xmltext}" xslt = "${xslt}"/>
   </body>
</html>

Aşağıdaki sonuç görüntülenecektir -

Books Info:

Padam History ZARA 100
Great Mistry NUHA 2000

JSTL kullanarak XML işleme hakkında daha fazla bilgi edinmek için JSP Standart Etiket Kitaplığı'na bakabilirsiniz .

Bir JavaBean, Java ile yazılmış ve JavaBeans API spesifikasyonlarına göre kodlanmış özel olarak oluşturulmuş bir Java sınıfıdır.

Bir JavaBean'ı diğer Java sınıflarından ayıran benzersiz özellikler şunlardır:

  • Varsayılan, bağımsız değişken içermeyen bir kurucu sağlar.

  • Serileştirilebilir ve uygulayabilen Serializable arayüz.

  • Okunabilen veya yazılabilen bir dizi özelliğe sahip olabilir.

  • Birkaç "getter" ve "setter"özellikler için yöntemler.

JavaBeans Özellikleri

JavaBean özelliği, nesnenin kullanıcısı tarafından erişilebilen adlandırılmış bir niteliktir. Öznitelik, tanımladığınız sınıflar dahil herhangi bir Java veri türünde olabilir.

Bir JavaBean özelliği olabilir read, write, read onlyveya write only. JavaBean özelliklerine, JavaBean'ın uygulama sınıfındaki iki yöntemle erişilir -

S.No. Yöntem ve Açıklama
1

almakPropertyName()

Örneğin, özellik adı firstName ise, yöntem adınızgetFirstName()bu özelliği okumak için. Bu yönteme erişimci denir.

2

AyarlamakPropertyName()

Örneğin, özellik adı firstName ise, yöntem adınızsetFirstName()bu özelliği yazmak için. Bu yönteme mutatör denir.

Salt okunur bir özniteliğin yalnızca bir getPropertyName() yöntem ve salt yazılır bir öznitelik yalnızca bir setPropertyName() yöntem.

JavaBeans Örneği

Birkaç özelliği olan bir öğrenci sınıfını düşünün -

package com.tutorialspoint;

public class StudentsBean implements java.io.Serializable {
   private String firstName = null;
   private String lastName = null;
   private int age = 0;

   public StudentsBean() {
   }
   public String getFirstName(){
      return firstName;
   }
   public String getLastName(){
      return lastName;
   }
   public int getAge(){
      return age;
   }
   public void setFirstName(String firstName){
      this.firstName = firstName;
   }
   public void setLastName(String lastName){
      this.lastName = lastName;
   }
   public void setAge(Integer age){
      this.age = age;
   }
}

JavaBeans'e Erişim

useBeaneylem, bir JSP'de kullanılmak üzere bir JavaBean bildirir. Bean, bildirildikten sonra hem komut dosyası oluşturma öğeleri hem de JSP'de kullanılan diğer özel etiketler tarafından erişilebilen bir komut dosyası oluşturma değişkeni haline gelir. UseBean etiketinin tam sözdizimi aşağıdaki gibidir -

<jsp:useBean id = "bean's name" scope = "bean's scope" typeSpec/>

Burada kapsam özniteliğinin değerleri bir page, request, session veya application basedihtiyacınıza göre. Değeriid özellik, diğerleri arasında benzersiz bir ad olduğu sürece herhangi bir değer olabilir useBean declarations aynı JSP'de.

Aşağıdaki örnek, useBean eyleminin nasıl kullanılacağını gösterir -

<html>
   <head>
      <title>useBean Example</title>
   </head>
   
   <body>
      <jsp:useBean id = "date" class = "java.util.Date" /> 
      <p>The date/time is <%= date %>
   </body>
</html>

Aşağıdaki sonucu alacaksınız - -

The date/time is Thu Sep 30 11:18:11 GST 2010

JavaBeans Özelliklerine Erişim

İle birlikte <jsp:useBean...> eylem, kullanabilirsiniz <jsp:getProperty/> alma yöntemlerine erişim eylemi ve <jsp:setProperty/>ayarlanan yöntemlere erişim eylemi. İşte tam sözdizimi -

<jsp:useBean id = "id" class = "bean's class" scope = "bean's scope">
   <jsp:setProperty name = "bean's id" property = "property name"  
      value = "value"/>
   <jsp:getProperty name = "bean's id" property = "property name"/>
   ...........
</jsp:useBean>

Name özniteliği, daha önce useBean eylemi tarafından JSP'ye sunulan bir JavaBean'ın kimliğine başvurur. Özellik özniteliği,get ya da set çağrılması gereken yöntemler.

Aşağıdaki örnek, yukarıdaki sözdizimi kullanılarak verilere nasıl erişileceğini gösterir -

<html>
   <head>
      <title>get and set properties Example</title>
   </head>
   
   <body>
      <jsp:useBean id = "students" class = "com.tutorialspoint.StudentsBean"> 
         <jsp:setProperty name = "students" property = "firstName" value = "Zara"/>
         <jsp:setProperty name = "students" property = "lastName" value = "Ali"/>
         <jsp:setProperty name = "students" property = "age" value = "10"/>
      </jsp:useBean>

      <p>Student First Name: 
         <jsp:getProperty name = "students" property = "firstName"/>
      </p>
      
      <p>Student Last Name: 
         <jsp:getProperty name = "students" property = "lastName"/>
      </p>
      
      <p>Student Age: 
         <jsp:getProperty name = "students" property = "age"/>
      </p>

   </body>
</html>

Yapalım StudentsBean.classCLASSPATH'da mevcuttur. Yukarıdaki JSP'ye erişin. aşağıdaki sonuç görüntülenecektir -

Student First Name: Zara 

Student Last Name: Ali 

Student Age: 10

Bu bölümde, JSP'deki Özel Etiketleri tartışacağız. Özel bir etiket, kullanıcı tanımlı bir JSP dil öğesidir. Özel bir etiket içeren bir JSP sayfası bir sunucu uygulamasına çevrildiğinde, etiket, etiket işleyici olarak adlandırılan bir nesne üzerindeki işlemlere dönüştürülür. Web kapsayıcısı daha sonra JSP sayfasının sunucu uygulaması yürütüldüğünde bu işlemleri başlatır.

JSP etiket uzantıları, bir JavaSunucusu Sayfasına doğrudan ekleyebileceğiniz yeni etiketler oluşturmanıza olanak sağlar. JSP 2.0 spesifikasyonu, bu özel etiketleri yazmak için Basit Etiket İşleyicileri tanıttı.

Özel bir etiket yazmak için, basitçe SimpleTagSupport sınıf ve geçersiz kılma doTag() etiket için içerik oluşturmak için kodunuzu yerleştirebileceğiniz yöntem.

"Merhaba" Etiketi Oluşturun

<Ex: Hello> adlı özel bir etiket tanımlamak istediğinizi ve bunu bir gövde olmadan aşağıdaki şekilde kullanmak istediğinizi düşünün -

<ex:Hello />

Özel bir JSP etiketi oluşturmak için, önce bir etiket işleyici olarak görev yapan bir Java sınıfı oluşturmanız gerekir. Şimdi oluşturalımHelloTag aşağıdaki gibi sınıf -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   public void doTag() throws JspException, IOException {
      JspWriter out = getJspContext().getOut();
      out.println("Hello Custom Tag!");
   }
}

Yukarıdaki kod, basit bir kodlamaya sahiptir. doTag() yöntemi, geçerli JspContext nesnesini kullanarak getJspContext() yöntem ve onu göndermek için kullanır "Hello Custom Tag!" akıntıya JspWriter nesne

Yukarıdaki sınıfı derleyelim ve CLASSPATH ortam değişkeninde bulunan bir dizine kopyalayalım. Son olarak, aşağıdaki etiket kitaplığı dosyasını oluşturun:<Tomcat-Installation-Directory>webapps\ROOT\WEB-INF\custom.tld.

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>empty</body-content>
   </tag>
</taglib>

Şimdi yukarıda tanımlanan özel etiketi kullanalım Hello JSP programımızda aşağıdaki gibi -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello/>
   </body>
</html>

Yukarıdaki JSP'yi arayın ve bu aşağıdaki sonucu vermelidir -

Hello Custom Tag!

Etiket Gövdesine Erişim

Standart etiketlerde gördüğünüz gibi etiketin gövdesine bir mesaj ekleyebilirsiniz. Adlı özel bir etiket tanımlamak istediğinizi düşünün<ex:Hello> ve bunu bir vücutla aşağıdaki şekilde kullanmak istiyorsanız -

<ex:Hello>
   This is message body
</ex:Hello>

Etiketin gövdesini işlemek için yukarıdaki etiket kodunda aşağıdaki değişiklikleri yapalım -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      getJspBody().invoke(sw);
      getJspContext().getOut().println(sw.toString());
   }
}

Burada, çağrıdan kaynaklanan çıktı ilk olarak bir StringWriteretiketiyle ilişkili JspWriter'a yazılmadan önce. TLD dosyasını aşağıdaki gibi değiştirmemiz gerekiyor -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
   </tag>
</taglib>

Şimdi yukarıdaki etiketi uygun gövdeli aşağıdaki gibi adlandıralım -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello>
         This is message body
      </ex:Hello>
   </body>
</html>

Aşağıdaki sonucu alacaksınız -

This is message body

Özel Etiket Özellikleri

Özel etiketlerinizle birlikte çeşitli öznitelikleri kullanabilirsiniz. Bir öznitelik değerini kabul etmek için özel bir etiket sınıfının şunu uygulaması gerekir:setter aşağıda gösterildiği gibi JavaBean ayarlayıcı yöntemleriyle aynı yöntemler -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   private String message;

   public void setMessage(String msg) {
      this.message = msg;
   }
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      if (message != null) {
         /* Use message from attribute */
         JspWriter out = getJspContext().getOut();
         out.println( message );
      } else {
         /* use message from the body */
         getJspBody().invoke(sw);
         getJspContext().getOut().println(sw.toString());
      }
   }
}

Özniteliğin adı "message", bu nedenle ayarlayıcı yöntemi setMessage(). Şimdi bu özniteliği TLD dosyasına ekleyelim.<attribute> aşağıdaki gibi eleman -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
      
      <attribute>
         <name>message</name>
      </attribute>
   
   </tag>
</taglib>

JSP'yi mesaj niteliği ile aşağıdaki gibi takip edelim -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello message = "This is custom tag" />
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

This is custom tag

Bir öznitelik için aşağıdaki özellikleri eklemeyi düşünün -

S.No. Mülkiyet ve Amaç
1

name

Name öğesi, bir özniteliğin adını tanımlar. Her öznitelik adı, belirli bir etiket için benzersiz olmalıdır.

2

required

Bu, bu özniteliğin gerekli olup olmadığını veya isteğe bağlı olduğunu belirtir. İsteğe bağlı olarak yanlış olur.

3

rtexprvalue

Bir etiket özniteliği için bir çalışma zamanı ifade değerinin geçerli olup olmadığını bildirir

4

type

Bu niteliğin Java sınıf türünü tanımlar. Varsayılan olarak şu varsayılır:String

5

description

Bilgilendirici açıklama sağlanabilir.

6

fragment

Bu öznitelik değerinin bir JspFragment.

Aşağıda, bir öznitelikle ilgili özellikleri belirtmek için örnek verilmiştir -

.....
   <attribute>
      <name>attribute_name</name>
      <required>false</required>
      <type>java.util.Date</type>
      <fragment>false</fragment>
   </attribute>
.....

İki öznitelik kullanıyorsanız, TLD'nizi aşağıdaki gibi değiştirebilirsiniz -

.....
   <attribute>
      <name>attribute_name1</name>
      <required>false</required>
      <type>java.util.Boolean</type>
      <fragment>false</fragment>
   </attribute>
   
   <attribute>
      <name>attribute_name2</name>
      <required>true</required>
      <type>java.util.Date</type>
   </attribute>
.....

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'nin 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 özelliğin geçerli değerleri doğru ve yanlıştır. Doğruysa, EL ifadeleri statik metin veya etiket özniteliklerinde göründüklerinde göz ardı edilir. 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

Daha 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 dizgenin 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 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.

Bu bölümde. JSP'de istisnaların nasıl ele alınacağını tartışacağız. Bir JSP kodu yazarken, kodun herhangi bir bölümünde meydana gelebilecek kodlama hataları yapabilirsiniz. JSP kodunuzda aşağıdaki türden hatalar meydana gelebilir -

Kontrol edilen istisnalar

Kontrol edilen bir istisna, tipik olarak bir kullanıcı hatası veya programcı tarafından öngörülemeyen bir sorun olan bir istisnadır. Örneğin, bir dosya açılacaksa ancak dosya bulunamıyorsa bir istisna oluşur. Bu istisnalar, derleme sırasında basitçe göz ardı edilemez.

Çalışma zamanı istisnaları

Çalışma zamanı istisnası, muhtemelen programcı tarafından önlenebilecek bir istisnadır. Kontrol edilen istisnaların aksine, çalışma zamanı istisnaları, uyum sırasında göz ardı edilir.

Hatalar

Bunlar hiçbir şekilde istisna değil, kullanıcının veya programcının kontrolü dışında ortaya çıkan sorunlardır. Bir hata hakkında nadiren herhangi bir şey yapabileceğiniz için, kodunuzda hatalar genellikle yok sayılır. Örneğin, bir yığın taşması meydana gelirse, bir hata ortaya çıkacaktır. Derleme sırasında da dikkate alınmazlar.

JSP kodunuzda meydana gelen çalışma zamanı istisnasını / hatasını işlemenin yollarını daha ayrıntılı olarak tartışacağız.

İstisna Nesnesini Kullanma

İstisna nesnesi, Throwable'ın bir alt sınıfının bir örneğidir (örneğin, java.lang. NullPointerException) ve yalnızca hata sayfalarında kullanılabilir. Aşağıdaki tablo Throwable sınıfında bulunan önemli yöntemleri listeler.

S.No. Yöntemler ve Açıklama
1

public String getMessage()

Oluşan istisna hakkında ayrıntılı bir mesaj verir. Bu mesaj Throwable yapıcısında başlatılır.

2

public Throwable getCause()

Throwable nesne tarafından temsil edildiği şekliyle istisnanın nedenini döndürür.

3

public String toString()

Sonucu ile birleştirilen sınıfın adını verir getMessage().

4

public void printStackTrace()

Sonucunu yazdırır toString() yığın iziyle birlikte System.err, hata çıktı akışı.

5

public StackTraceElement [] getStackTrace()

Yığın izlemesindeki her bir öğeyi içeren bir dizi döndürür. 0 dizinindeki öğe, çağrı yığınının üstünü temsil eder ve dizideki son öğe, çağrı yığınının altındaki yöntemi temsil eder.

6

public Throwable fillInStackTrace()

Bu Throwable nesnesinin yığın izlemesini, yığın izlemedeki önceki bilgilere ekleyerek geçerli yığın izlemesiyle doldurur.

JSP size şunu belirtme seçeneği sunar: Error Pageher JSP için. Sayfa bir istisna attığında, JSP kapsayıcısı otomatik olarak hata sayfasını çağırır.

Aşağıda, bir hata sayfası belirtmek için bir örnek verilmiştir. main.jsp. Bir hata sayfası oluşturmak için,<%@ page errorPage = "xxx" %> direktif.

<%@ page errorPage = "ShowError.jsp" %>

<html>
   <head>
      <title>Error Handling Example</title>
   </head>
   
   <body>
      <%
         // Throw an exception to invoke the error page
         int x = 1;
         
         if (x == 1) {
            throw new RuntimeException("Error condition!!!");
         }
      %>
   </body>
</html>

Şimdi aşağıda verilen bir Hata İşleme JSP ShowError.jsp yazacağız. Hata işleme sayfasının yönergeyi içerdiğine dikkat edin<%@ page isErrorPage = "true" %>. Bu yönerge, JSP derleyicisinin istisna durum değişkenini oluşturmasına neden olur.

<%@ page isErrorPage = "true" %>

<html>
   <head>
      <title>Show Error Page</title>
   </head>
   
   <body>
      <h1>Opps...</h1>
      <p>Sorry, an error occurred.</p>
      <p>Here is the exception stack trace: </p>
      <pre><% exception.printStackTrace(response.getWriter()); %></pre>
   </body>
</html>

Erişmek main.jsp, aşağıdakine benzer bir çıktı alacaksınız -

java.lang.RuntimeException: Error condition!!!
......

Opps...
Sorry, an error occurred.

Here is the exception stack trace:

Hata Sayfası için JSTL Etiketlerini Kullanma

Bir hata sayfası yazmak için JSTL etiketlerini kullanabilirsiniz. ShowError.jsp. Bu sayfa, daha iyi bir yapıya ve daha fazla bilgiye sahip, yukarıdaki örnekteki ile hemen hemen aynı mantığa sahiptir -

<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@page isErrorPage = "true" %>

<html>
   <head>
      <title>Show Error Page</title>
   </head>
   
   <body>
      <h1>Opps...</h1>
      <table width = "100%" border = "1">
         <tr valign = "top">
            <td width = "40%"><b>Error:</b></td>
            <td>${pageContext.exception}</td>
         </tr>
            
         <tr valign = "top">
            <td><b>URI:</b></td>
            <td>${pageContext.errorData.requestURI}</td> </tr> <tr valign = "top"> <td><b>Status code:</b></td> <td>${pageContext.errorData.statusCode}</td>
         </tr>
            
         <tr valign = "top">
            <td><b>Stack trace:</b></td>
            <td>
               <c:forEach var = "trace" 
                  items = "${pageContext.exception.stackTrace}"> <p>${trace}</p>
               </c:forEach>
            </td>
         </tr>
      </table>

   </body>
</html>

Main.jsp'ye erişin, aşağıdakiler oluşturulacaktır -

Opps...

Error:

java.lang.RuntimeException: Error condition!!!

URI:

/main.jsp

Status code:

500

Stack trace:

org.apache.jsp.main_jsp._jspService(main_jsp.java:65)

org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:68)

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265)

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

Try Kullanma ... Yakalama Bloğu

Aynı sayfadaki hataları işlemek ve bir hata sayfası tetiklemek yerine bazı işlemler yapmak istiyorsanız, try....catch blok.

Aşağıda, try ... catch bloğunun nasıl kullanılacağını gösteren basit bir örnek verilmiştir. Aşağıdaki kodu main.jsp içine koyalım -

<html>
   <head>
      <title>Try...Catch Example</title>
   </head>
   
   <body>
      <%
         try {
            int i = 1;
            i = i / 0;
            out.println("The answer is " + i);
         }
         catch (Exception e) {
            out.println("An exception occurred: " + e.getMessage());
         }
      %>
   </body>
</html>

Main.jsp'ye erişin, aşağıdaki gibi bir çıktı oluşturmalıdır -

An exception occurred: / by zero

Bu bölümde, JSP'de Hata Ayıklamayı tartışacağız. Bir JSP'yi ve sunucu uygulamalarını test etmek / hata ayıklamak her zaman zordur. JSP ve Servletler, büyük miktarda istemci / sunucu etkileşimi içerme eğilimindedir, bu da hataları olası ancak yeniden üretilmesini zorlaştırır.

Aşağıda, hata ayıklamanıza yardımcı olabilecek birkaç ipucu ve öneri bulunmaktadır.

System.out.println () kullanma

System.out.println()belirli bir kod parçasının yürütülüp yürütülmediğini test etmek için bir işaretçi olarak kullanımı kolaydır. Değişken değerleri de yazdırabiliriz. Aşağıdaki ek noktaları göz önünde bulundurun -

  • Sistem nesnesi çekirdek Java nesnelerinin bir parçası olduğu için, herhangi bir ekstra sınıf yüklemeye gerek kalmadan her yerde kullanılabilir. Bu içerirServlets, JSP, RMI, EJB's, ordinary Beans ve classes, ve standalone applications.

  • Kesme noktalarında durmakla karşılaştırıldığında, System.out uygulamanın normal yürütme akışına fazla müdahale etmez, bu da iming önemli olduğunda onu çok değerli kılar.

Kullanılacak sözdizimi aşağıdadır System.out.println() -

System.out.println("Debugging message");

Aşağıdaki örnek nasıl kullanılacağını gösterir System.out.print() -

<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>

<html>
   <head><title>System.out.println</title></head>
   <body>
      <c:forEach var = "counter" begin = "1" end = "10" step = "1" >
      
         <c:out value = "${counter-5}"/></br>
         <% System.out.println( "counter = " + pageContext.findAttribute("counter") ); %>
      </c:forEach>
      
   </body>
</html>

Yukarıdaki JSP'ye erişin, tarayıcı aşağıdaki sonucu gösterecektir -

-4
-3
-2
-1
0
1
2
3
4
5

Tomcat kullanıyorsanız, bu satırları sayfanın sonuna eklenmiş olarak da bulacaksınız. stdout.log günlükler dizininde.

counter = 1
counter = 2
counter = 3
counter = 4
counter = 5
counter = 6
counter = 7
counter = 8
counter = 9
counter = 10

Bu şekilde, değişkenleri ve diğer bilgileri, sorunun temel nedenini bulmak için veya diğer çeşitli nedenlerle analiz edilebilecek sistem günlüğüne getirebilirsiniz.

JDB Logger'ı kullanma

J2SEgünlük çerçevesi, JVM'de çalışan herhangi bir sınıf için günlük kaydı hizmetleri sağlamak üzere tasarlanmıştır. Herhangi bir bilgiyi kaydetmek için bu çerçeveyi kullanabiliriz.

JDK logger API kullanarak yukarıdaki örneği yeniden yazalım -

<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@page import = "java.util.logging.Logger" %>

<html>
   <head><title>Logger.info</title></head>
   
   <body>
      <% Logger logger = Logger.getLogger(this.getClass().getName());%>

      <c:forEach var = "counter" begin = "1" end = "10" step = "1" >
      <c:set var = "myCount" value = "${counter-5}" />
      <c:out value = "${myCount}"/></br>
         <% String message = "counter = "
            + pageContext.findAttribute("counter") + "myCount = "
            + pageContext.findAttribute("myCount");
            logger.info( message );
         %>
      </c:forEach>
      
   </body>
</html>

Yukarıdaki kod, tarayıcıda ve stdout.log'da benzer bir sonuç üretecek, ancak şurada ek bilgilere sahip olacaksınız: stdout.log. Kullanacağızinfologger yöntemi çünkü ve mesajı sadece bilgi amaçlı olarak kaydeder. Aşağıda stdout.log dosyasının bir anlık görüntüsü verilmiştir -

24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 1 myCount = -4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 2 myCount = -3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 3 myCount = -2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 4 myCount = -1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 5 myCount = 0
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 6 myCount = 1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 7 myCount = 2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 8 myCount = 3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 9 myCount = 4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 10 myCount = 5

Kolaylık fonksiyonları kullanılarak çeşitli seviyelerde mesaj gönderilebilir severe(), warning(), info(), config(), fine(), finer(), ve finest(). Burada finest () yöntemi, en iyi bilgileri günlüğe kaydetmek için kullanılabilir ve ciddi () yöntemi ciddi bilgileri günlüğe kaydetmek için kullanılabilir.

Log4J Framework'ü , önem seviyelerine ve önemlerine göre farklı dosyalardaki mesajları günlüğe kaydetmek için kullanabilirsiniz .

Hata Ayıklama Araçları

NetBeans, bağımsız Java uygulamalarının ve JSP'yi ve servlet belirtimlerini destekleyen Web uygulamalarının geliştirilmesini destekleyen ve ayrıca bir JSP hata ayıklayıcı içeren ücretsiz ve açık kaynaklı bir Java Tümleşik Geliştirme Ortamıdır.

NetBeans, aşağıdaki temel hata ayıklama işlevlerini destekler -

  • Breakpoints
  • Kodda ilerlemek
  • Watchpoints

Hakemlik yapabilirsin NetBeans documentation yukarıdaki hata ayıklama işlevlerini anlamak için.

JDB Hata Ayıklayıcısını Kullanma

JSP ve sunucu uygulamalarının hatalarını aynı şekilde jdb bir uygulama veya uygulamada hata ayıklamak için kullandığınız komutlar.

Bir JSP veya sunucu uygulamasında hata ayıklamak için, sun.servlet.http.HttpServer, ardından HttpServer'ın bir tarayıcıdan yaptığımız HTTP isteklerine yanıt olarak JSP / sunucu uygulamalarını çalıştırdığını gözlemleyin. Bu, uygulamaların nasıl hata ayıklandığına çok benzer. Aradaki fark, uygulamalarda hata ayıklanan asıl programınsun.applet.AppletViewer.

Çoğu hata ayıklayıcı, uygulamalarda nasıl hata ayıklanacağını otomatik olarak bilerek bu ayrıntıyı gizler. JSP için aynısını yapana kadar, aşağıdakileri göz önünde bulundurarak hata ayıklayıcınıza yardım etmelisiniz -

  • Hata ayıklayıcınızın sınıf yolunu ayarlayın. Bu bulmana yardımcı olursun.servlet.http.Http-Server ve ilişkili sınıflar.

  • Hata ayıklayıcınızın sınıf yolunu ayarlayın. Bu, JSP'nizi ve destek sınıflarınızı bulmanıza yardımcı olur, genellikleROOT\WEB-INF\classes.

Uygun sınıf yolunu ayarladıktan sonra, hata ayıklamaya başlayın sun.servlet.http.HttpServer. Hata ayıklamayla ilgilendiğiniz JSP'de kesme noktaları ayarlayabilir, ardından verilen JSP için HttpServer'a istekte bulunmak için bir web tarayıcısı kullanabilirsiniz.(http://localhost:8080/JSPToDebug). Buradaki yürütme, kesme noktalarında durur.

Yorumları Kullanma

Kodunuzdaki yorumlar, hata ayıklama sürecine çeşitli şekillerde yardımcı olabilir. Yorumlar, hata ayıklama sürecinde birçok başka şekilde kullanılabilir.

JSP, Java yorumlarını kullanır ve single line (// ...) ve multiple line (/* ... */)yorumlar Java kodunuzun bazı kısımlarını geçici olarak kaldırmak için kullanılabilir. Hata ortadan kalkarsa, az önce yorumladığınız koda daha yakından bakın ve sorunu bulun.

İstemci ve Sunucu Başlıkları

Bazen bir JSP beklendiği gibi davranmadığında, ham HTTP isteğine ve yanıtına bakmak yararlıdır. HTTP'nin yapısına aşinaysanız, isteği ve yanıtı okuyabilir ve bu başlıklarla tam olarak ne olduğunu görebilirsiniz.

Önemli Hata Ayıklama İpuçları

İşte JSP hata ayıklamayla ilgili daha fazla hata ayıklama ipucunun listesi -

  • Bir tarayıcıdan, görüntülediği sayfanın ham içeriğini göstermesini isteyin. Bu, biçimlendirme sorunlarının belirlenmesine yardımcı olabilir. Genellikle Görünüm menüsünün altındaki bir seçenektir.

  • Sayfayı tam olarak yeniden yüklemeye zorlayarak tarayıcının önceki bir isteğin çıktısını önbelleğe almadığından emin olun. İleNetscape Navigator, kullan Shift-Reload; ileInternet Explorer kullanım Shift-Refresh.

JavaServer Sayfaları ve sunucu uygulamaları, uygulamaların güvenliğini sağlamak için Web geliştiricilerine çeşitli mekanizmalar sunar. Kaynaklar, uygulama dağıtım tanımlayıcısında tanımlanarak ve bunlara bir rol atanarak bildirimsel olarak korunur.

Tanımlayıcıları ve parolaları kullanarak temel kimlik doğrulamasından, sertifika kullanan gelişmiş kimlik doğrulamaya kadar çeşitli kimlik doğrulama düzeyleri mevcuttur.

Rol Tabanlı Kimlik Doğrulama

Sunucu uygulaması belirtimindeki kimlik doğrulama mekanizması, role-based security. Buradaki fikir, kaynakları kullanıcı düzeyinde kısıtlamak yerine roller oluşturup kaynakları role göre kısıtlamanızdır.

Dosyada farklı roller tanımlayabilirsiniz tomcat-users.xml, Tomcat'in ana dizininin dışında conf. Bu dosyanın bir örneği aşağıda gösterilmiştir -

<?xml version = '1.0' encoding = 'utf-8'?>
<tomcat-users>
   <role rolename = "tomcat"/>
   <role rolename = "role1"/>
   <role rolename = "manager"/>
   <role rolename = "admin"/>
   <user username = "tomcat" password = "tomcat" roles = "tomcat"/>
   <user username = "role1" password = "tomcat" roles = "role1"/>
   <user username = "both" password = "tomcat" roles = "tomcat,role1"/>
   <user username = "admin" password = "secret" roles = "admin,manager"/>
</tomcat-users>

Bu dosya, aşağıdakiler arasında basit bir eşlemeyi tanımlar: username, password, ve role. Belirli bir kullanıcının birden çok rolü olabileceğine dikkat edin; Örneğin,username = "both" "tomcat" rolü ve "role1" rolünde.

Farklı rolleri tanımlayıp tanımladıktan sonra, rol tabanlı güvenlik kısıtlamaları farklı Web Uygulama kaynaklarına yerleştirilebilir. <security-constraint> eleman web.xml dosyası WEB-INF dizininde mevcuttur.

Aşağıda web.xml'de örnek bir giriş yer almaktadır -

<web-app>
   ...
   <security-constraint>
      <web-resource-collection>
         <web-resource-name>SecuredBookSite</web-resource-name>
         <url-pattern>/secured/*</url-pattern>
         <http-method>GET</http-method>
         <http-method>POST</http-method>
      </web-resource-collection>
      
      <auth-constraint>
         <description>
            Let only managers use this app
         </description>
         <role-name>manager</role-name>
      </auth-constraint>
   </security-constraint>
   
   <security-role>
      <role-name>manager</role-name>
   </security-role>
   
   <login-config>
      <auth-method>BASIC</auth-method>
   </login-config>
   ...
</web-app>

Yukarıdaki girişler şu anlama gelir:

  • / Secured / * ile eşleşen bir URL'ye yönelik herhangi bir HTTP GET veya POST isteği, güvenlik kısıtlamasına tabi olacaktır.

  • Yönetici rolüne sahip bir kişiye güvenli kaynaklara erişim verilir.

  • login-config öğesi açıklamak için kullanılır BASIC kimlik doğrulama şekli.

Şunlar dahil herhangi bir URL'ye göz atmayı denerseniz /securitydizininde, kullanıcı adı ve şifre isteyen aşağıdaki iletişim kutusu görüntülenecektir. Bir kullanıcı sağlarsanız"admin" ve şifre "secret", sonra ile eşleşen URL'ye erişiminiz olacak /secured/* Bu kaynağa erişmesine izin verilen yönetici rolüne sahip kullanıcı yöneticisini tanımladığımızdan.

Form Tabanlı Kimlik Doğrulama

FORM kimlik doğrulama yöntemini kullandığınızda, kullanıcıdan bir kullanıcı adı ve parola istemek için bir oturum açma formu sağlamanız gerekir. Aşağıdaki basit bir koddurlogin.jsp. Bu, aynı amaç için bir form oluşturmaya yardımcı olur -

<html>
   <body bgcolor = "#ffffff">
      
      <form method = "POST" action ="j_security_check">
         <table border = "0">
            <tr>
               <td>Login</td>
               <td><input type = "text" name="j_username"></td>
            </tr>
            <tr>
               <td>Password</td>
               <td><input type = "password" name="j_password"></td>
            </tr>
         </table>
         <input type = "submit" value = "Login!">
      </form>
      
   </body>
</html>

Burada, giriş formunun adlı form öğelerini içermesi gerektiğinden emin olmalısınız j_username ve j_password. Eylem<form> etiket olmalı j_security_check. POSTform yöntemi olarak kullanılmalıdır. Aynı zamanda,<login-config> kimlik doğrulama yöntemini FORM olarak belirtmek için etiket -

<web-app>
   ...
   <security-constraint>
      <web-resource-collection>
         <web-resource-name>SecuredBookSite</web-resource-name>
         <url-pattern>/secured/*</url-pattern>
            <http-method>GET</http-method>
            <http-method>POST</http-method>
      </web-resource-collection>
      
      <auth-constraint>
         <description>Let only managers use this app</description>
         <role-name>manager</role-name>
      </auth-constraint>
   </security-constraint>
   
   <security-role>
      <role-name>manager</role-name>
   </security-role>
   
   <login-config>
      <auth-method>FORM</auth-method>
      <form-login-config>
         <form-login-page>/login.jsp</form-login-page>
         <form-error-page>/error.jsp</form-error-page>
      </form-login-config>
   </login-config>
   ...
</web-app>

Şimdi herhangi bir kaynağa erişmeye çalıştığınızda URL /secured/*, kullanıcı kimliği ve şifresini soran yukarıdaki formu gösterecektir. Konteyner "j_security_check"eylem, arayanın kimliğini doğrulamak için bazı dahili mekanizmalar kullanır.

Oturum açma başarılı olursa ve arayan kişi güvenli kaynağa erişme yetkisine sahipse, o noktadan sonra konteyner, arayan için bir oturum açma oturumu tanımlamak için bir oturum kimliği kullanır. Kap, oturum kimliğini içeren bir tanımlama bilgisi ile oturum açma oturumunu korur. Sunucu, çerezi müşteriye geri gönderir ve arayan bu çerezi sonraki isteklerle birlikte sunduğu sürece, kapsayıcı arayanın kim olduğunu bilecektir.

Oturum açma başarısız olursa, sunucu form-error-page ayarıyla tanımlanan sayfayı geri gönderir

Buraya, j_security_checkform tabanlı oturum açma kullanan uygulamaların oturum açma formu için belirtmesi gereken eylemdir. Aynı biçimde, adında bir metin giriş denetiminiz de olmalıdır.j_username ve bir password input control aranan j_password. Bunu gördüğünüzde, formda yer alan bilgilerin sunucuya gönderileceği, ad ve şifreyi kontrol edeceği anlamına gelir. Bunun nasıl yapıldığı sunucuya özeldir.

Nasıl olduğunu anlamak için Standart Bölge Uygulamalarını kontrol edinj_security_check Tomcat konteyner için çalışıyor ..

Bir Sunucu Uygulamasında / JSP'de Programatik Güvenlik

HttpServletRequest nesnesi, çalışma zamanında güvenlik bilgileri araştırmak için kullanılabilecek aşağıdaki yöntemleri sağlar -

S.No. Yöntem ve Açıklama
1

String getAuthType()

getAuthType() yöntem, Servlet'i korumak için kullanılan kimlik doğrulama şemasının adını temsil eden bir String nesnesi döndürür.

2

boolean isUserInRole(java.lang.String role)

isUserInRole() yöntem bir boole değeri döndürür: kullanıcı verilen roldeyse true, değilse false.

3

String getProtocol()

getProtocol()yöntem, isteği göndermek için kullanılan protokolü temsil eden bir String nesnesi döndürür. Bu değer, güvenli bir protokolün kullanılıp kullanılmadığını belirlemek için kontrol edilebilir.

4

boolean isSecure()

isSecure()yöntem, isteğin HTTPS kullanılarak yapılıp yapılmadığını temsil eden bir boole değeri döndürür. True değeri, bunun olduğu ve bağlantının güvenli olduğu anlamına gelir. Yanlış değeri, isteğin olmadığı anlamına gelir.

5

Principle getUserPrinciple()

getUserPrinciple() yöntem, geçerli kimliği doğrulanmış kullanıcının adını içeren bir java.security.Principle nesnesi döndürür.

Örneğin, yöneticiler için sayfalara bağlanan bir JavaSunucusu Sayfası için aşağıdaki koda sahip olabilirsiniz -

<% if (request.isUserInRole("manager")) { %>
   <a href = "managers/mgrreport.jsp">Manager Report</a>
   <a href = "managers/personnel.jsp">Personnel Records</a>
<% } %>

Kullanıcının bir JSP veya sunucu uygulamasındaki rolünü kontrol ederek, Web sayfasını kullanıcıya yalnızca erişebildiği öğeleri gösterecek şekilde özelleştirebilirsiniz. Kimlik doğrulama formuna girildiği şekliyle kullanıcı adına ihtiyacınız varsa,getRemoteUser yöntem istek nesnesinde.

Bu bölümde, JSP'de Uluslararasılaşma kavramını tartışacağız. Devam etmeden önce, aşağıdaki üç önemli terimi anlayalım:

  • Internationalization (i18n) - Bu, bir web sitesinin ziyaretçinin diline veya uyruğuna çevrilmiş farklı içerik sürümleri sunmasını sağlamak anlamına gelir.

  • Localization (l10n) - Bu, belirli bir coğrafi veya kültürel bölgeye uyarlamak için bir web sitesine kaynak eklemek anlamına gelir, örneğin bir web sitesine Hintçe çeviri.

  • locale- Bu belirli bir kültürel veya coğrafi bölgedir. Genellikle bir dil sembolü ve ardından bir alt çizgi ile ayrılmış bir ülke sembolü olarak anılır. Örneğin, "en_US"ABD için İngilizce yerel ayarını temsil eder.

Küresel bir Web sitesi oluştururken dikkat edilmesi gereken birkaç öğe vardır. Bu eğitim size bu konuda tam bir ayrıntı vermeyecek, ancak Web sayfanızı farklı dillerde internet topluluğuna konumlarını, yani yerelleri farklılaştırarak nasıl sunabileceğiniz konusunda size iyi bir örnek verecektir.

Bir JSP, talepte bulunan kişinin yerel ayarına dayalı olarak sitenin uygun sürümünü alabilir ve yerel dil, kültür ve gereksinimlere göre uygun site sürümünü sağlayabilir. Aşağıda, Locale nesnesini döndüren istek nesnesinin yöntemi verilmiştir.

java.util.Locale request.getLocale()

Yerel Algılama

Aşağıdakiler, tespit etmek için kullanabileceğiniz önemli yerel yöntemlerdir. requester's location, language ve tabi ki locale. Aşağıdaki yöntemlerin tümü, talepte bulunan kişinin tarayıcısında belirlenen ülke adını ve dil adını görüntüler.

S.No. Yöntem ve Açıklama
1

String getCountry()

Bu yöntem, ISO 3166 2 harfli formatta bu yerel ayar için ülke / bölge kodunu büyük harflerle döndürür.

2

String getDisplayCountry()

Bu yöntem, yerel ayarın ülkesi için kullanıcıya görüntülenmeye uygun bir ad döndürür.

3

String getLanguage()

Bu yöntem, ISO 639 biçiminde bu yerel ayar için dil kodunu küçük harflerle döndürür.

4

String getDisplayLanguage()

Bu yöntem, yerelin dili için kullanıcıya görüntülenmeye uygun bir ad döndürür.

5

String getISO3Country()

Bu yöntem, bu yerel ayarın ülkesi için üç harfli bir kısaltma döndürür.

6

String getISO3Language()

Bu yöntem, bu yerelin dili için üç harfli bir kısaltma döndürür.

Misal

Aşağıdaki örnek, bir JSP'de bir istek için bir dilin ve ilişkili ülkenin nasıl görüntüleneceğini gösterir -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%
   //Get the client's Locale
   Locale locale = request.getLocale();
   String language = locale.getLanguage();
   String country = locale.getCountry();
%>

<html>
   <head>
      <title>Detecting Locale</title>
   </head>

   <body>
      <center>
         <h1>Detecting Locale</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Language : " + language  + "<br />");
            out.println("Country  : " + country   + "<br />");
         %>
      </p>
   </body>
</html>

Diller Ayarı

Bir JSP, İngilizce, İspanyolca, Almanca, Fransızca, İtalyanca, Hollandaca gibi bir Batı Avrupa dilinde yazılmış bir sayfanın çıktısını alabilir. Burada, tüm karakterleri düzgün şekilde görüntülemek için İçerik-Dil başlığının ayarlanması önemlidir.

Bir diğer önemli nokta, tüm özel karakterleri HTML varlıklarını kullanarak görüntülemektir; Örneğin,"&#241;" temsil eder "ñ", ve "&#161;" temsil eder "¡" aşağıdaki gibi -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>

<%
   // Set response content type
   response.setContentType("text/html");
   
   // Set spanish language code.
   response.setHeader("Content-Language", "es");
   String title = "En Español";
%>

<html>
   <head>
      <title><%  out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><%  out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>En Español</p>
         <p>¡Hola Mundo!</p>
      </div>
   </body>
</html>

Yerel Ayara Özel Tarihler

Kullanabilirsiniz java.text.DateFormat sınıf ve statik getDateTimeInstance( )yerel ayara özel tarih ve saati biçimlendirme yöntemi. Aşağıda, belirli bir yerel ayara özgü tarihlerin nasıl biçimlendirileceğini gösteren örnek verilmiştir -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.DateFormat,java.util.Date" %>

<%
   String title = "Locale Specific Dates";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   String date = DateFormat.getDateTimeInstance(
      DateFormat.FULL, 
      DateFormat.SHORT, 
      locale).format(new Date( ));
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Local Date: <%  out.print(date); %></p>
      </div>
   </body>
</html>

Yerel Ayara Özgü Para Birimi

Kullanabilirsiniz java.txt.NumberFormat sınıf ve statik getCurrencyInstance( )yerel ayara özgü bir para biriminde uzun veya çift tür gibi bir sayıyı biçimlendirme yöntemi. Aşağıda, belirli bir yerel ayara özel para biriminin nasıl biçimlendirileceğini gösteren örnek verilmiştir -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.NumberFormat,java.util.Date" %>

<%
   String title = "Locale Specific Currency";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   NumberFormat nft = NumberFormat.getCurrencyInstance(locale);
   String formattedCurr = nft.format(1000000);
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Formatted Currency: <%  out.print(formattedCurr); %></p>
      </div>
   </body>
</html>

Yerel Ayara Özgü Yüzde

Kullanabilirsiniz java.txt.NumberFormat sınıf ve statik getPercentInstance( )yerel ayar yüzdesini elde etme yöntemi. Aşağıdaki örnek, belirli bir yerel ayara özgü yüzdelerin nasıl biçimlendirileceğini gösterir -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.NumberFormat,java.util.Date" %>

<%
   String title = "Locale Specific Percentage";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   NumberFormat nft = NumberFormat.getPercentInstance(locale);
   String formattedPerc = nft.format(0.51);
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Formatted Percentage: <%  out.print(formattedPerc); %></p>
      </div>
   </body>
</html>