客戶端禁用cookie情況下的URL重寫:
servlet:
package com.stono.servlet.listenerorder; 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; import javax.servlet.http.HttpSession; public class SessionON extends HttpServlet { private static final long serialVersionUID = 1L; @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { HttpSession session = req.getSession(); // 如果客戶端的cookie禁用,每次獲得的session都是新的;在chrome Developer Tools中的Cookies界面可以看到沒有request的JSESSIONID; // 判斷獲得的session是否是新的; boolean new1 = session.isNew(); System.out.println("session is " + new1); PrintWriter writer = resp.getWriter(); writer.println("com.stono.servlet.listenerorder.SessionON.doGet(HttpServletRequest, HttpServletResponse)"); // 使用response.sendRedirect(response.encodeRedirectURL("b.do"))進行URL重寫; // 在客戶端可以看到形如:TestBootWeb/b.do;jsessionid=6047B41B7A2D066E803FBA68C88E40F8的格式的URL; // 這樣在b.do中其session就可以記住當前的頁面a.do的session; resp.sendRedirect(resp.encodeRedirectURL("b.do")); // 在JSP中使用response.encodeURL("xxx.do");進行編寫; } }