1.1、会话

会话:用户打开一个浏览器,点击了很多超链接,访问多个web资源,关闭浏览器,这个过程可以称之为会话;

有状态会话:一个同学来过教室,下次再来教室,我们会知道这个同学,曾经来过,称之为有状态会话;

你能怎么证明你是华水的学生?
学校登记过了,有记录,录取你了,给你发了学生证。

一个网站,怎么证明你来过?

客户端 服务端

(1)服务端给客户端一个 信件,客户端下次访问服务端带上信件就可以了; cookie
(2)服务器登记你来过了,下次你来的时候我来匹配你; seesion

1.2、保存会话的两种技术

Cookie:
客户端技术 (响应,请求)

Session:
服务器技术,利用这个技术,可以保存用户的会话信息? 我们可以把信息或者数据放在session中!就比如说,你登陆了bilibli一次,你关闭浏览器,关闭了会话,再进去就还是登录着的。

1.3、Cookie

cookie是啥,是个饼干,也就是我们(客户端)请求服务器要带的东西,也就是类似于发票和学校的记录,去证明我们去某家饭店吃过饭或者说我们属于这个学校。

  1. 从请求中拿到cookie信息
  2. 服务器响应给客户端cookie ```java public class CookieDemo extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

    1. //解决中文乱码
    2. req.setCharacterEncoding("utf-8");
    3. resp.setCharacterEncoding("utf-8");
    4. PrintWriter out = resp.getWriter();
    5. //cookie是不是要从request里面拿
    6. Cookie[] cookies = req.getCookies();//是可能存在多个
    7. //判断cookie是否存在
    8. if (cookies!=null)
    9. //如果存在的话
    10. {
    11. out.write("你上一次访问的时间是:");
    12. for (int i = 0;i<cookies.length;i++){
    13. Cookie cookie = cookies[i];
    14. //获取cookie的名字
    15. //如果cookie的名字为name则获取cookie的值
    16. if (cookie.getName().equals("LastLoginTime"))
    17. {
    18. long lastLoginTime = Long.parseLong(cookie.getValue());
    19. Date date = new Date(lastLoginTime);
    20. out.write(date.toLocaleString());
    21. }
    22. }
    23. }
    24. else
    25. {
    26. out.write("这是第一次访问本站");
    27. }
    28. //服务给客户端响应一个cookie
    29. Cookie cookie = new Cookie("LastLoginTime", System.currentTimeMillis()+"");
    30. resp.addCookie(cookie);

    }

    @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

    1. doPost(req, resp);

    } }

``` cookie:一般会保存在本地的 用户目录下 appdata;

一个网站cookie是否存在上限呢?

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

1.4、Session

什么是Session:

服务器会给每一个用户(浏览器)创建一个Seesion对象;
一个Seesion独占一个浏览器,只要浏览器没有关闭,这个Session就存在;
用户登录之后,整个网站它都可以访问!–> 保存用户的信息;保存购物车的信息……

Session和cookie的区别:

Cookie是把用户的数据写给用户的浏览器,浏览器保存 (可以保存多个);
Session把用户的数据写到用户独占Session中,服务器端保存 (保存重要的信息,减少服务器资源的浪费);
Session对象由服务创建;

使用场景:
保存一个登录用户的信息;
购物车信息;
在整个网站中经常会使用的数据,我们将它保存在Session中;

[

](https://blog.csdn.net/bell_love/article/details/105667638)
[

](https://blog.csdn.net/bell_love/article/details/105667638)