Servlets - Pelacakan Sesi

HTTP adalah protokol "stateless" yang berarti setiap kali klien mengambil halaman Web, klien membuka koneksi terpisah ke server Web dan server secara otomatis tidak menyimpan catatan apa pun dari permintaan klien sebelumnya.

Masih ada tiga cara berikut untuk mempertahankan sesi antara klien web dan server web -

Kue

Server web dapat menetapkan ID sesi unik sebagai cookie untuk setiap klien web dan untuk permintaan berikutnya dari klien, mereka dapat dikenali menggunakan cookie yang diterima.

Ini mungkin bukan cara yang efektif karena sering kali browser tidak mendukung cookie, jadi saya tidak akan merekomendasikan untuk menggunakan prosedur ini untuk mempertahankan sesi.

Bidang Formulir Tersembunyi

Server web dapat mengirim bidang formulir HTML tersembunyi bersama dengan ID sesi unik sebagai berikut -

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

Entri ini berarti bahwa, ketika formulir dikirimkan, nama dan nilai yang ditentukan secara otomatis disertakan dalam data GET atau POST. Setiap kali browser web mengirim permintaan kembali, nilai session_id dapat digunakan untuk melacak browser web yang berbeda.

Ini bisa menjadi cara yang efektif untuk melacak sesi tetapi mengklik tautan hypertext biasa (<A HREF...>) tidak menghasilkan pengiriman formulir, jadi bidang formulir tersembunyi juga tidak dapat mendukung pelacakan sesi umum.

Penulisan Ulang URL

Anda dapat menambahkan beberapa data tambahan di akhir setiap URL yang mengidentifikasi sesi, dan server dapat mengaitkan pengidentifikasi sesi tersebut dengan data yang telah disimpan tentang sesi tersebut.

Misalnya, dengan http://tutorialspoint.com/file.htm;sessionid = 12345, pengenal sesi dilampirkan sebagai sessionid = 12345 yang dapat diakses di server web untuk mengidentifikasi klien.

Penulisan ulang URL adalah cara yang lebih baik untuk mempertahankan sesi dan berfungsi bahkan ketika browser tidak mendukung cookie. Kelemahan dari penulisan ulang URL adalah Anda harus membuat setiap URL secara dinamis untuk menetapkan ID sesi, bahkan untuk halaman HTML statis sederhana.

Objek HttpSession

Terlepas dari tiga cara yang disebutkan di atas, servlet menyediakan HttpSession Interface yang menyediakan cara untuk mengidentifikasi pengguna di lebih dari satu permintaan halaman atau kunjungan ke situs Web dan untuk menyimpan informasi tentang pengguna itu.

Kontainer servlet menggunakan antarmuka ini untuk membuat sesi antara klien HTTP dan server HTTP. Sesi berlanjut untuk jangka waktu tertentu, di lebih dari satu koneksi atau permintaan halaman dari pengguna.

Anda akan mendapatkan objek HttpSession dengan memanggil metode publik getSession() dari HttpServletRequest, seperti di bawah ini -

HttpSession session = request.getSession();

Anda perlu memanggil request.getSession () sebelum Anda mengirim konten dokumen apa pun ke klien. Berikut adalah ringkasan dari metode penting yang tersedia melalui objek HttpSession -

Sr.No. Metode & Deskripsi
1

public Object getAttribute(String name)

Metode ini mengembalikan objek yang terikat dengan nama yang ditentukan dalam sesi ini, atau null jika tidak ada objek yang terikat di bawah namanya.

2

public Enumeration getAttributeNames()

Metode ini mengembalikan Enumerasi objek String yang berisi nama semua objek yang terikat ke sesi ini.

3

public long getCreationTime()

Metode ini mengembalikan waktu saat sesi ini dibuat, diukur dalam milidetik sejak tengah malam 1 Januari 1970 GMT.

4

public String getId()

Metode ini mengembalikan string yang berisi pengenal unik yang ditetapkan untuk sesi ini.

5

public long getLastAccessedTime()

Metode ini mengembalikan waktu sesi yang terakhir diakses, dalam format milidetik sejak tengah malam 1 Januari 1970 GMT

6

public int getMaxInactiveInterval()

Metode ini mengembalikan interval waktu maksimum (detik), bahwa wadah servlet akan membuat sesi tetap terbuka antara akses klien.

7

public void invalidate()

Metode ini membatalkan sesi ini dan melepaskan semua objek yang terikat padanya.

8

public boolean isNew(

Metode ini mengembalikan nilai true jika klien belum mengetahui tentang sesi atau jika klien memilih untuk tidak bergabung dengan sesi.

9

public void removeAttribute(String name)

Metode ini menghapus objek yang terikat dengan nama yang ditentukan dari sesi ini.

10

public void setAttribute(String name, Object value)

Metode ini mengikat objek ke sesi ini, menggunakan nama yang ditentukan.

11

public void setMaxInactiveInterval(int interval)

Metode ini menentukan waktu, dalam detik, antara permintaan klien sebelum kontainer servlet akan membatalkan sesi ini.

Contoh Pelacakan Sesi

Contoh ini menjelaskan cara menggunakan objek HttpSession untuk mengetahui waktu pembuatan dan waktu akses terakhir untuk sebuah sesi. Kami akan mengasosiasikan sesi baru dengan permintaan jika belum ada.

// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
 
// Extend HttpServlet class
public class SessionTrack extends HttpServlet {
 
   public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
         
      // Create a session object if it is already not  created.
      HttpSession session = request.getSession(true);
         
      // Get session creation time.
      Date createTime = new Date(session.getCreationTime());
         
      // Get last access time of this web page.
      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 web page.
      if (session.isNew()) {
         title = "Welcome to my website";
         session.setAttribute(userIDKey, userID);
      } else {
         visitCount = (Integer)session.getAttribute(visitCountKey);
         visitCount = visitCount + 1;
         userID = (String)session.getAttribute(userIDKey);
      }
      session.setAttribute(visitCountKey,  visitCount);

      // Set response content type
      response.setContentType("text/html");
      PrintWriter out = response.getWriter();

      String docType =
         "<!doctype html public \"-//w3c//dtd html 4.0 " +
         "transitional//en\">\n";

      out.println(docType +
         "<html>\n" +
            "<head><title>" + title + "</title></head>\n" +
            
            "<body bgcolor = \"#f0f0f0\">\n" +
               "<h1 align = \"center\">" + title + "</h1>\n" +
               "<h2 align = \"center\">Session Infomation</h2>\n" +
               "<table border = \"1\" align = \"center\">\n" +
                  
                  "<tr bgcolor = \"#949494\">\n" +
                     "  <th>Session info</th><th>value</th>
                  </tr>\n" +
                     
                  "<tr>\n" +
                     "  <td>id</td>\n" +
                     "  <td>" + session.getId() + "</td>
                  </tr>\n" +
                  
                  "<tr>\n" +
                     "  <td>Creation Time</td>\n" +
                     "  <td>" + createTime + "  </td>
                  </tr>\n" +
                  
                  "<tr>\n" +
                     "  <td>Time of Last Access</td>\n" +
                     "  <td>" + lastAccessTime + "  </td>
                  </tr>\n" +
                  
                  "<tr>\n" +
                     "  <td>User ID</td>\n" +
                     "  <td>" + userID + "  </td>
                  </tr>\n" +
                  
                  "<tr>\n" +
                     "  <td>Number of visits</td>\n" +
                     "  <td>" + visitCount + "</td>
                  </tr>\n" +
               "</table>\n" +
            "</body>
         </html>"
      );
   }
}

Kompilasi servlet di atas SessionTrackdan buat entri yang sesuai di file web.xml. Sekarang menjalankan http: // localhost: 8080 / SessionTrack akan menampilkan hasil berikut saat Anda menjalankan untuk pertama kali -

Welcome to my website

Session Infomation

Session info value
id 0AE3EC93FF44E3C525B4351B77ABB2D5
Creation Time Tue Jun 08 17:26:40 GMT+04:00 2010
Time of Last Access Tue Jun 08 17:26:40 GMT+04:00 2010
User ID ABCD
Number of visits 0

Sekarang coba jalankan servlet yang sama untuk kedua kalinya, itu akan menampilkan hasil sebagai berikut.

Welcome Back to my website

Session Infomation

info type value
id 0AE3EC93FF44E3C525B4351B77ABB2D5
Creation Time Tue Jun 08 17:26:40 GMT+04:00 2010
Time of Last Access Tue Jun 08 17:26:40 GMT+04:00 2010
User ID ABCD
Number of visits 1

Menghapus Data Sesi

Saat Anda selesai dengan data sesi pengguna, Anda memiliki beberapa opsi -

  • Remove a particular attribute- Anda dapat memanggil metode public void removeAttribute (nama string) untuk menghapus nilai yang terkait dengan kunci tertentu.

  • Delete the whole session- Anda dapat memanggil metode public void invalidate () untuk membuang seluruh sesi.

  • Setting Session timeout- Anda dapat memanggil metode public void setMaxInactiveInterval (int interval) untuk menyetel batas waktu untuk sesi individual.

  • Log the user out - Server yang mendukung servlet 2.4, Anda dapat menghubungi logout untuk mengeluarkan klien dari server Web dan membatalkan semua sesi milik semua pengguna.

  • web.xml Configuration - Jika Anda menggunakan Tomcat, selain metode yang disebutkan di atas, Anda dapat mengonfigurasi waktu tunggu sesi di file web.xml sebagai berikut.

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

Batas waktu dinyatakan sebagai menit, dan menggantikan batas waktu default yaitu 30 menit di Tomcat.

Metode getMaxInactiveInterval () dalam servlet mengembalikan periode waktu tunggu untuk sesi itu dalam hitungan detik. Jadi jika sesi Anda dikonfigurasi di web.xml selama 15 menit, getMaxInactiveInterval () mengembalikan 900.