会话

  • 一个网站怎么证明用户访问过

    • 服务端给客户端一个信件,客户端下次访问服务端带上信件就可以:cookie

    • 服务器登记,下次访问匹配:session

  • 保存会话的技术

    • cookie

      • 客户端技术(响应、请求)
    • session

      • 服务器技术,利用这个技术,可以保存用户的会话信息,可以把信息或数据保存在session中
  • Cookie

    • 从请求中获得cookie信息

    • 服务器响应给客户端

  1. 1 req.setCharacterEncoding("utf-8");
  2. 2 resp.setContentType("text/html;charset=UTF-8");
  3. 3 resp.setCharacterEncoding("utf-8");
  4. 4
  5. 5 PrintWriter out = resp.getWriter();
  6. 6
  7. 7
  8. 8 Cookie[] cookies = req.getCookies();
  9. 9
  10. 10 //判断cookie是否为空
  11. 11 if (cookies != null) {
  12. 12 out.write("你上一次访问的时间是:");
  13. 13 for (int i = 0; i < cookies.length; i++) {
  14. 14 Cookie cookie = cookies[i];
  15. 15 //获取名字
  16. 16 if(cookie.getName().equals("lastLoginTime")){
  17. 17 //获取值
  18. 18 long l = Long.parseLong(cookie.getValue());
  19. 19 Date date = new Date(l);
  20. 20 out.write(date.toLocaleString());
  21. 21 }
  22. 22
  23. 23 }
  24. 24 } else {
  25. 25 out.write("这是你第一次访问本站");
  26. 26 }
  27. 27
  28. 28 Cookie cookie=new Cookie("lastLoginTime", ""+System.currentTimeMillis());
  29. 29 //给cookie设置有效期
  30. 30 cookie.setMaxAge(24*60*60);
  31. 31
  32. 32 resp.addCookie(cookie);
    • 一般会保存在本地的用户目录下的appdata

    • 一个网站的cookie是否存在上限

      • 一个cookie只能保存一个信息
      • 一个web站点可以给浏览器发送多个cookie,最多存放20个
      • cookie有大小限制:4kb
      • 浏览器上限:300个cookie
    • 删除cookie

      • 不设置有效期,关闭浏览器自动小时
      • 设置有效期为0
  • Session

    • 什么是Session

      • 服务器会给每一个用户(浏览器)创建一个Session对象

      • 一个session独占一个浏览器,浏览器不关闭,session就还在

      • 用户登录以后整个网站都可以访问

    • Session和Cookie区别

      • Cookie:把用户的数据写给用户的浏览器,浏览器保存;可以保存多个
      • Session:把用户的数据写到用户独占的Session中,服务器保存;保存重要信息;由服务器创建
    • 使用场景

      • 保存一个登录用户的信息
      • 购物车信息
      • 在整个网站中经常使用到的数据
  1. 1      req.setCharacterEncoding("utf-8");
  2. 2 resp.setCharacterEncoding("utf-8");
  3. 3 resp.setContentType("text/html;charset=utf-8");
  4. 4
  5. 5 //得到Session
  6. 6 HttpSession session = req.getSession();
  7. 7 //给Session存数据
  8. 8 session.setAttribute("name", new Person("Cra2iTeT",1));
  9. 9 //获取Session的id
  10. 10 String id = session.getId();
  11. 11 //判断是否是新创建的
  12. 12 if (session.isNew()) {
  13. 13 resp.getWriter().write("session创建成功,ID:" + id);
  14. 14 }else {
  15. 15 resp.getWriter().write("session已经存在,ID:" + id);
  16. 16 }
  1. 1 req.setCharacterEncoding("utf-8");
  2. 2 resp.setCharacterEncoding("utf-8");
  3. 3 resp.setContentType("text/html;charset=utf-8");
  4. 4
  5. 5 //得到Session
  6. 6 HttpSession session = req.getSession();
  7. 7 //给Session存数据
  8. 8 Person person = (Person) session.getAttribute("name");
  9. 9 System.out.println(person.toString());
  1. 1 HttpSession session = req.getSession();
  2. 2 session.removeAttribute("name");
  3. 3 //手动注销
  4. 4 session.invalidate();
  1. 1 <!-- 设置session的默认注销时间-->
  2. 2 <session-config>
  3. 3 <!-- 十五分钟后Session自动失效-->
  4. 4 <session-timeout>15</session-timeout>
  5. 5 </session-config>

JavaWeb入门day9-随笔(session/cookie)的更多相关文章

  1. 超全面的JavaWeb笔记day11<JSP&Session&Cookie&HttpSession>

    1.JSP 2.回话跟踪技术 3.Cookie 4.HttpSession JSP入门 1 JSP概述 1.1 什么是JSP JSP(Java Server Pages)是JavaWeb服务器端的动态 ...

  2. JavaWeb学习篇之----Session&&Cookie

    今天继续来看看JavaWeb的相关知识,这篇文章主要来讲一下Session和Cookie的相关知识,首先我们来看一下Cookie的相关知识: 一.Cookie 简介: Cookie是客户端技术,服务器 ...

  3. [Web][学习随笔]Session&cookie

    Session 从登录建立连接到退出就是一次会话.Session数据就会在会话期间用户存在服务器端的数据.这样,当用户在Web页之间跳转时,存储在Session对象中的变量将不会丢失,而是在整个用户会 ...

  4. [转载]JavaEE学习篇之——Session&&Cookie

    原文链接: http://blog.csdn.net/jiangwei0910410003/article/details/23337043 今天继续来看看JavaWeb的相关知识,这篇文章主要来讲一 ...

  5. 第一篇 Flask基础篇之(配置文件,路由系统,模板,请求响应,session&cookie)

    Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后 ...

  6. session & cookie(li)

    Session & Cookie 一.定义 Session,用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间.Cookie,由服务器端生成,发送 ...

  7. web也是区分前端与后端的,session\cookie辨析

    <1>Ajax交互方式 Ext.Ajax.request( { //被用来向服务器发起请求默认的url url : "", //请求时发送后台的参数,既可以是Json对 ...

  8. 浅析session&cookie

    session&cookie没有出现的黑暗时代 大家都知道,HTTP协议是一种无状态的协议,本次请求下一次请求没有任何的关联,所有没有办法直接用http协议来记住用户的信息,试想一向,每一次点 ...

  9. http之Session&Cookie

    百度了一波session与Cookie,我发现这东西远比我想象中更复杂(可能是因为我不明白底层的运行原理).网上也是一堆的关于Session与Cookie区别/联系的文章,然而,我看完了还是一脸懵逼的 ...

  10. Asp.net MVC使用Model Binding解除Session, Cookie等依赖

    上篇文章"Asp.net MVC使用Filter解除Session, Cookie等依赖"介绍了如何使用Filter来解除对于Session, Cookie的依赖.其实这个也可以通 ...

随机推荐

  1. 在 Ubuntu 上使用源码安装 OpenResty

    镜像下载.域名解析.时间同步请点击 阿里云开源镜像站 本文将介绍如何在 Ubuntu 上使用源码安装 OpenResty. 目标 Ubuntu 18.04 OpenResty 1.19.3.2 安装依 ...

  2. 使用cgroup和tc限制带宽

    cgroup子系统net_cls 可以给 packet 打上 classid 的标签,用于过滤分类,这个classid就是用于标记skb所属的 qdisc class 的.有了这个标签,流量控制器(t ...

  3. SQL Server 2008安全加固手册

    1.身份鉴别 1.1避免使用空密码和弱口令 要求:应对登录操作系统和数据库系统的用户进行身份标识和鉴别. 目的:操作系统和数据库系统管理用户身份鉴别信息应具有不易被冒用的特点,口令应有复杂度要求并定期 ...

  4. Knife4j 注解详谈

    Controller层添加注解 @Api:用于类:表示标识这个类是swagger的资源 属性名称 数据类型   默认值  说明  value      String  ""  字段 ...

  5. flask 数据库一节笔记

    笔记一:os.path的用法:1. os.path.dirname(__file__)   返回当前脚本的执行路径,__file__为固定参数2. os.path.abspath(file)     ...

  6. 【ASP.NET Core】MVC模型绑定:自定义InputFormatter读取CSV内容

    在上一篇文章中,老周介绍了用自定义 ModelBinder 的方式实现一个 API(或MVC操作方法)可以同时支持 JSON 格式和 Form-data 格式的数据正文.今天该轮到 InputForm ...

  7. SpringCloudAlibaba 微服务讲解(四)Sentinel--服务容错(一)

    4.1 高并发带来的问题 在微服务中,我们将业务拆分成一个个的服务,服务与服务之间可以相互调用,但是由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现网 ...

  8. 半吊子菜鸟学Web开发6 -- Vscode开发环境配置

    1vscode上手一周不到,终于弄出点门路,终于弄清楚了点vscode的设置是什么样子的了....哭 2就我这两天的使用来看,一般vscode默认只让打开一个文件夹,然后在你打开的文件夹里面自动生成 ...

  9. 使用Redis实现关注好友的功能

    现在很多社交都有关注或者添加粉丝的功能, 类似于这样的功能我们如果采用数据库做的话只是单纯得到用户的一些粉丝或者关注列表的话是很简单也很容易实现, 但是如果我想要查出两个甚至多个用户共同关注了哪些人或 ...

  10. springboot 设定访问项目的根路径

    springboot的配置文件application.yml: spring.mvc.view.prefix : / spring.mvc.view.suffix : .html server: po ...