session中的地址重写

本文介绍了URL重写技术在禁用Cookie环境下的重要性及其实现方式,通过Java示例代码展示了如何确保session正常工作,即使在用户禁用了Cookie的情况下也能保持会话状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

地址重写,主要是为了防止有些浏览器,为了提高安全性,禁止了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. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值