session应用 20111025

session

在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。
Session和Cookie的主要区别在于:
Cookie是把用户的数据写给用户的浏览器。
Session技术把用户的数据写到用户独占的session中。
Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。

注意,虽然代码相同,但不同浏览器得到的是各自的数据

实现关闭浏览器,再打开(10分钟内)加入购物车的商品还在,代码如下:

  Cookie cookie = new Cookie("JSESSIONID",session.getId());
  cookie.setMaxAge(10*60);//使cookie临时文件有效期为10分钟
  cookie.setPath("/201110251");
  response.addCookie(cookie);

IE禁用Cookie后的session处理

当cookie被禁用后,cookier 无法传JSESSIONID,即服务器无法响应。处理方法如下:

用于对sendRedirect方法后的url地址进行重写:

String url = response.encodeRedirectURL("/201110251/servlet/ListCartsServlet");
 response.sendRedirect(url);

用于对表单action和超链接的url地址进行重写

String url = response.encodeURL("/201110251/servlet/BuyServlet");

out.println(entity.getName()+"<a href='"+url+"?id="+entity.getId()+"'>加入购物车</a></br>");

重写之后,即可解决该问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值