URL地址重写

本文探讨了URL地址重写的技术原理及其在禁用cookie情况下的应用价值,通过实例展示了如何在Servlet中实现URL重写以确保session功能的正常运行。
    为什么使用URL地址重写? 
    因为有些浏览器的安全设置,禁用了session.而session的原理则是把session的ID保存在客户端的cookie中。所以这个时候如果cookie功能被禁用的话,所有使用session的功能将失效.如果采用url地址重写技术,则server会把session经过编码以后,写到url地址后面当做参数来传递.这样既提高了客户端的安全性,同时也避免了功能被屏蔽的风险.下面是一个使用url地址重写的servlet例子.其中核心代码为 
resp.encodeURL(req.getRequestURL().toString()); 

Java代码  收藏代码
  1. public class SessionTest extends HttpServlet {  
  2.   
  3.     protected void doGet(HttpServletRequest req, HttpServletResponse resp)  
  4.             throws ServletException, IOException {  
  5.         PrintWriter out = resp.getWriter();  
  6.         HttpSession session =req.getSession(true);// true代表先从客户端获取cookie  
  7.           
  8.         out.flush();  
  9.         out.close();  
  10.           
  11.         /* 
  12.          * session默认,也是要把sessionID写到客户端的内存当中(内存cookie) 
  13.          * 重写地址,防止禁用cookie的时候,仍然可以使用session 
  14.          */  
  15.         resp.encodeURL(req.getRequestURL().toString());  
  16.   
  17.         //地址编码,在url中,传递中文  
  18.         org.apache.jasper.runtime.JspRuntimeLibrary.URLEncode(String s ,request.getCharacterEncoding());  
  19.     }  
  20.   
  21.     protected void doPost(HttpServletRequest req, HttpServletResponse resp)  
  22.             throws ServletException, IOException {  
  23.         doGet(req, resp);  
  24.     }  
  25.   
  26. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值