在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。
Session和Cookie的主要区别在于:
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禁用cookie后session的处理)
// //响应到另一个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);
}
}