session中的地址重寫

 

session中的地址重寫

博客分類: JavaEE
    地址重寫,主要是爲了防止有些瀏覽器,爲了提高安全性,禁止了Cookie的功能,而session的ID恰好是保存在web容器中和客戶端的內存當中的。所以一旦禁用了cookie,session也會無法使用.所以url重寫技術就誕生了.像以前的新浪郵箱就沒有采用url地址重寫,導致了禁用cookie的時候,是無法進行操作的.
Java代碼 複製代碼 收藏代碼
  1. import java.io.IOException;   
  2. import java.io.PrintWriter;   
  3.   
  4. import javax.servlet.*;   
  5. import javax.servlet.http.*;   
  6.   
  7. public class SessionTest extends HttpServlet {   
  8.   
  9.     protected void doGet(HttpServletRequest req, HttpServletResponse resp)   
  10.             throws ServletException, IOException {   
  11.         PrintWriter out = resp.getWriter();   
  12.         HttpSession session =req.getSession(true);// true代表先從客戶端獲取cookie   
  13.            
  14.         out.flush();   
  15.         out.close();   
  16.            
  17.         /*  
  18.          * session默認,也是要把sessionID寫到客戶端的內存當中(內存cookie)  
  19.          * 重寫地址,防止禁用cookie的時候,仍然可以使用session  
  20.          */  
  21.         resp.encodeURL(req.getRequestURL().toString());   
  22.   
  23.         //地址編碼,在url中,傳遞中文   
  24.         org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode(String s ,request.getCharacterEncoding());   
  25.     }   
  26.   
  27.     protected void doPost(HttpServletRequest req, HttpServletResponse resp)   
  28.             throws ServletException, IOException {   
  29.         doGet(req, resp);   
  30.     }   
  31.   
  32. }  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章