20111025

来源:互联网 发布:一键apache php mysql 编辑:程序博客网 时间:2024/05/16 18:24
WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。

SessionCookie的主要区别在于:

Cookie是把用户的数据写给用户的浏览器。

Session技术把用户的数据写到用户独占的session中。

Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。

使用Session完成简单的购物功能:

public class BuyServlet extends HttpServlet {

private static final long serialVersionUID = 1L;

private GoodsService gService = new GoodsServiceImpl();

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

        //传递的参数  获取其值   

String rid = request.getParameter("id");

//类型转换

           Integer id = Integer.parseInt(rid);

           //执行查询

           Goods entity = gService.findById(id);

           //session中获取carts

           HttpSession session = request.getSession();

           //实现关闭浏览器 再打开(15分钟内)  加入购物车的商品还在

           Cookie cookie = new Cookie("JSESSIONID",session.getId());

           cookie.setMaxAge(10*60);

           cookie.setPath("/201110251");

           response.addCookie(cookie);   

           @SuppressWarnings("unchecked")

List<Goods> carts = (List<Goods>) session.getAttribute("carts");

           //判断

           if(carts==null){

            carts = new ArrayList<Goods>();

            session.setAttribute("carts", carts);

           }

          //添加到集合中

           carts.add(entity);

         //响应到另一个Servlet

         response.sendRedirect("/201110251/servlet/ListCartsServlet");        

         //购物车实现3(IE禁用cookiesession的处理)

//  //响应到另一个Servlet

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

//  response.sendRedirect(url);

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

           this.doGet(request, response);

}

}


原创粉丝点击