JSP - Müşteri İsteği
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 bilgiler 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. Bir değerKeep-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çeriklerin farklı tarayıcı türlerine döndürülmesi için kullanılabilir. |
HttpServletRequest Nesnesi
İstek nesnesi bir örneğidir 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 mevcut 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 veya verilen adın hiçbir ö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 null 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() Bu isteğin yapıldığı HTTP yönteminin adını döndürür, örneğin GET, POST veya PUT. |
16 | String getParameter(String name) Bir istek parametresinin değerini Dize olarak veya parametre yoksa 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 nesnesi 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 buraya 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.