生活随笔
收集整理的這篇文章主要介紹了
URL重写实现会话跟踪
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
IT程序員開發必備-各類資源下載清單,史上最全IT資源,個人收藏總結!
為了防止用戶禁用cookie,可以使用URL重寫技術來實現會話跟蹤!
url重寫原理:當服務器程序調用request.getSession();代碼時,其會先看request.getCookies()方法中有沒有名為JSESSIONID的cookie帶過來,如果沒有,就看URL有沒有被重寫(即附帶JSESSIONID),如果有,則從服務器中找key為JSESSIONID的session對象,如果都沒有,則創建一個新的session。如果用戶禁用了cookie,則只能通過URL重寫方式實現會話跟蹤!
一、在Servlet中實現URL重寫:
?? 客戶端在訪問本Servlet后,會返回主頁面:
package edu.session;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class EncodeURL extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setCharacterEncoding("utf-8");response.setContentType("text/html;charset=utf-8");PrintWriter out = response.getWriter();request.getSession(); //創建session//調用response的encodeURL方法,將自動將JSESSION追加到url后面,如:url;jsessionid=BD111FFC653497E81B702A29B3AC6FE4String buyurl = response.encodeURL("/CookieAndSession/servlet/buy");String payurl = response.encodeURL("/CookieAndSession/servlet/pay");out.print("<a href='"+buyurl+"'>購買</a><br/>");out.print("<a href='"+payurl+"'>結賬</a><br/>");}}
http://localhost:8080/CookieAndSession/servlet/encodeurl(此事后cookie被禁用了)
源代碼:
這樣即可實現回跟蹤。
? 注意:
? 1. 但是如果用戶禁用cookie,則關閉了瀏覽器后,重新開啟瀏覽器,則回話失效,無法實現回話跟蹤;如果是用戶沒有禁用cookie,則可以通過設置裝載JSESSIONID的cookie的失效時間來控制瀏覽器關閉后session仍未失效。
?? 2.如果用戶沒有禁用cookie,而且又使用URL重寫,則:用戶在第一次訪問EncodeURLServlet時,由于不知道用戶是否禁用了cookie,所以response.encodeURL()方法內部會將JSESSIONID重寫在url上,但是一旦第二次訪問時,由于用戶是帶著cookie來的,所以response.encodeURL()不會將JSESSIONID重寫在url上。
總結
以上是生活随笔為你收集整理的URL重写实现会话跟踪的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。