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>");
重写之后,即可解决该问题。