JSP - Oturum İzleme

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, istemcinin Web sunucusuna ayrı bir bağlantı açması ve sunucunun otomatik olarak önceki istemci isteğinin kaydını tutmamasıdır.

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 desteklemediklerinde 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 etkinleştirilmiştir 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 bağlı nesneyi döndürür veya ad altında hiçbir nesne bağlı değilse null döndürür.

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'den bu yana 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 arayabilirsin 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 o 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.