做购物车的时候,我们都知道购买的东西会保存到 session 中,但是光这样简单的保存起来就会带来一个问题,只能呢被同一个浏览器访问到,如果用户使用不同的浏览器进行访问网页的话肯定是会出问题的。下面就来针对这样的问题解决一下。
我们知道 cookie 是可以实现不同浏览器之间共享的,所以解决办法就朝向了怎么实现将 session 对象写入到 cookie 中,下面是解决代码:
- protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException,
- IOException {
- response.setContentType("text/html;charset=utf-8");
- PrintWriter out = response.getWriter();
- //创建一个session,并放入一个属性
- HttpSession session = request.getSession();
- session.setAttribute("username", "张三");
- //把session id保存到cookie,在保存id时一定要按照规范存放,这里区分大小写
- Cookie cookie = new Cookie("JSESSIONID", session.getId());
- cookie.setMaxAge(60 * 30); //设置声明周期
- response.addCookie(cookie); //将cookie回写
- }
读取 session 时方式还是和原来的一样,不变
来源: http://www.bubuko.com/infodetail-2447103.html