JSP - Sunucu Yanıtı
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 önbelleğin 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. Bir değerclose 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 bu nedenle 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 eklenmelidir. 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 gösteren bir mantıksal değer döndürür. |
5 | void addCookie(Cookie cookie) Belirtilen tanımlama bilgisini 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 ad ve tamsayı değerine sahip bir yanıt başlığı ekler. |
9 | void flushBuffer() Arabellekteki herhangi bir içeriği istemciye yazmaya 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ıtta 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.