Session
程序员文章站
2022-06-10 14:02:57
...
Session(服务器端)
javax.servlet.http
Interface HttpSession
public interface HttpSession
cookie是基于客户端的,不安全,而且有大小和个数的限制。
session域对象,范围一次会话的范围,存个人相关的数据。
在web中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其他程序时,其他程序可以从用户的session中取出该用户的数据,为用户服务。
- Session 和Cookie 的主要区别在于:
- Cookie是把用户的数据写给用户的浏览器
- Session技术把用户的数据写到用户独占的session中(服务器端)
- Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。
成员方法
- public Object getAttribute(String name)
返回与此会话中的指定名称绑定在一起的对象,如果没有对象绑定在该名称下,则返回 null。- public void setAttribute(String name, Object value)
使用指定名称将对象绑定到此会话。如果具有同样名称的对象已经绑定到该会话,则替换该对象。- public String getId();获取session的唯一id
返回包含分配给此会话的唯一标识符的字符串。标识符是由 servlet 容器分配的,并且是与实现相关的。- public void invalidate();销毁session
使此会话无效,然后取消对任何绑定到它的对象的绑定。
案例
简单购物车的实现
- 购物车
Map<String,Integer>
cart 购物车,把购物车存入到Session中
分析
- 1 购物车
Map<String,Integer> cart
- 2 先获取购物车,判断是否是第一次访问
- 第一次访问:创建购物车,把商品名称和数量加入到购物车,存入到session中
- 不是第一次访问
- 判断是否包含该商品,通过名称
- 如果包含,数量+1 存入session中
- 如果不包含,存入购物车,存入session中
- 3 继续购物或者结算
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//获取参数
String id = req.getParameter("id");
//购物车存入商品的名称和数量
String[] names ={"手电筒","冰箱","电视","洗衣机","电脑"};
//把id 翻译成名称
int id1 = Integer.parseInt(id);
//商品名称
String name = names[id1 - 1];
//从session中获取购物车
HttpSession session = req.getSession();
//获取购物车,正常返回是一个Object类型的,此处强制类型转换
Map<String,Integer> cart=(Map<String,Integer>) session.getAttribute("cart");
//通过cart进行判断,判断是否是第一次访问
if(cart == null){
//创建购物车
cart = new HashMap<String,Integer>();
//第一次访问
cart.put(name,1);
//存入到session中
session.setAttribute("cart",cart);
}else{
//不是第一次访问,判断是否包含该商品
if(cart.containsKey(name)){
//包含,取出数量+1,存入购物车,存入session
//取出
Integer count = cart.get(name);
count++;
//购物车存入的商品
cart.put(name,count);
//存入购物车
session.setAttribute("cart",cart);
}else{
//不包含
cart.put(name,1);
//存入session中
session.setAttribute("cart",cart);
}
}
//继续购物或结算
resp.setContentType("text/html;charset=UTF-8");
resp.getWriter().write("<h3><a href='/JSPDdemo1/jsp/cartList.jsp'>继续购物</a> | <a href='/JSPDdemo1/jsp/pay.jsp'>去结算</a></h3>");
}
上一篇: session使用实例
下一篇: 虎扑步行街爬虫分析
推荐阅读
-
MSM--Memcached_Session_Manager介绍及使用
-
php5 的 session 详解其一: 什么是 session?
-
轻松掌握PHP Session使用方法_PHP教程
-
简单的方法让你的后台登录更加安全(php中加session验证)
-
解决php中Cannot send session cache limiter 的有关问题
-
Cannot convert value of type ‘java.lang.String‘ to required type ‘org.apache.ibatis.session.SqlSessi
-
PHP程序中使用session错误调试问题_PHP教程
-
PHP GD 生成图片验证码+session获取储存验证码
-
Warning: session_destroy : Trying to destroy uninitialized sessionq错误
-
php实现session自定义会话处理器的方法_PHP