JSP - Çerezlerin Kullanımı
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 iade edilmesinin üç 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ı bir sonraki sefer web sunucusuna 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 sonra ç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ı şunun gibi 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ı daha sonra 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, tanımlama bilgisinin süresi dolmadan önce ne kadar zaman geçmesi gerektiğini (saniye cinsinden) 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 bilgisi 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");
Unutmayın, adın veya değerin beyaz boşluk veya aşağıdaki karakterlerden herhangi birini içermemesi gerekir -
[ ] ( ) = , " / ? @ : ;
2. Adım: 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 süreyle 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 çerezleri 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 nesnesi oluşturmalısınız .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 buraya 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.jspdosyasını açın 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.