Javaweb学习笔记5—CookieSession

2024-01-31 05:30

本文主要是介绍Javaweb学习笔记5—CookieSession,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



前几天博客被黑了,导致博客登陆不上,把前几天应该发的东西的东西重新发一遍


今天来讲javaweb的第五阶段学习。 

CookieSession同样是web开发常用到的地方。

老规矩,首先先用一张思维导图来展现今天的博客内容。

ps:我的思维是用的xMind画的,如果你对我的思维导图感兴趣并且想看到你们跟详细的备注信息,请点击下载

另外:如果图看不清的话请右击---在新窗口中打开会清楚很多。


一、会话管理技术概述

    1 什么是会话?

         这里的会话指的是web开发中的一次通话过程,当打开浏览器,访问网站地址后,会话开始,当关闭浏览器(或者到了过期时间),会话结束。

        例如:我们去网吧上网,在吧台拿到用户名和密码,然后找机器登录,这时候机器就认识了我们,我们就可以开始上网,这就相当于我们开启了一次上网的会话,当我们点击结束下机(或者遇到关机重启),或者上网时间到了,这时候机器就不再认识我们,那么就叫会话结束。

    2 会话管理技术能做什么?

        共享同一个客户浏览器多个请求中数据,例如购物车。(简单权限过滤)

二、客户端会话管理技术(Cookie):

    1 什么是Cookie

        它是客户端浏览器的缓存文件

里面记录了客户浏览器访问网站的一些内容。

它也是Http协议请求和响应消息头的一部分。(回顾http协议)

    2 Cookie能做什么?

        能保存客户浏览器访问网站的相关内容(需要服务器开启Cookie)。从而在每次访问需要同一个内容时,先从本地缓存获取,使资源共享,并且提高效率。

        Cookie有大小,个数限制。每个网站最多只能存20cookie,且大小不能超过4kb(32bit不能超过4096MB)同时,所有网站的cookie总数不超过300个。

    3 Cookie中的属性

        属性:

            name:必要属性,cookie的名称。

            value:必要属性,cookie的值(不能是中文)

            ---------------------------可选属性---------------------------------

            path:cookie的    路径(重要)

            domain:cookie的域名(重要),相当于访问的网站(localhost

            maxAge:cookie的生存时间(相当于生命周期的活着)(比较重要),

                     当删除cookie时,设置该值为0

                     当不设置该值时,使用的是浏览器的内存,当关闭浏览器之后,cookie将丢失。设置了此值,就会保存成缓存文件(值必须是大于0,以秒为单位)。

            version:cookie的版本号。(不重要)

            comment:cookie的说明。(不重要)

    4 web应用中如何设置和获取Cookie

        定义一个Cookie

            Cookie cookie = new Cookie(cookieName,cookieValue);

        HttpServletRequest 获取 Cookie

            Cookie[] cookies = request.getCookies();

            该方法返回的是一个数组。(为什么是数组呢,方便,可以直接拿到与该请求相关的所有cookie)

        HttpServletResponse 添加Cookie

            response.addCookie(cookie);

        添加一个cookie,其实就是添加一个响应消息头

                response.setHeader("Set-Cookie","name=value;path=;maxage=;domain=");

        (为什么没有set方法,原因是set就会把之前的覆盖,所以每次都是添加)。

        如何确定一个唯一的cookiecookieName+cookiePath+cookieDomain

        定位一个cookie是由cookie的名称和路径,主机(访问的资源)三部分组成

    5 掌握Cookie的案例:

        A:使用Cookie技术获取最后访问时间(清除Cookie,设置maxAge(0));

        B:CookiePath(必须搞明白,什么时候浏览器带给服务器,什么时候不带)

        C:记录用户登录时的登录名

        D:记录浏览顺序

三、服务端会话管理技术(HttpSession):

    1、什么是HttpSession

            它是一个服务端会话对象,存储用户的会话数据。

    2、获取session的两种方式

            方式一:request:getSession();

            执行过程如下:

        方式二:request.getSession(boolean b);

        

        常用的几个方法:

            void setAttribute(String key,Object value);

            Object getAttribute(String key);

            void removeAttribute(String key);

            String getId();

        

    HttpSession的invalidate方法:作用是使session立即失效。

    设置HttpSession的过期时间,Tomcat的默认过期时间是30分钟。

    3HttpSession的生命周期

        出生——活着——死亡

        出生:调用getSession方法后会话开始

        活着:只要没有关闭会话(关闭浏览器)或者调用立即失效方法。或者服务器意外,                HttpSession一直存在

        死亡:调用立即失效方法invalidate,到了过期时间,关闭会话,服务器意外。

    4、域对象(三缺一了)

        HttpSession:也是一个域对象,它比application域范围小,比request域范围大

         

    5 、三个案例

        A 简单购物车实现

        B 防止表单重复提交

        C 完成用户登录,记录用户名和密码

    6、客户端禁用Cookie后会话数据的保持

        方式1:使用文字提示。163邮箱就是使用的这种方式。

        方式2URL重写。

                解释:当禁用了cookie之后,客户端永远都不会带Cookie到服务器。

                解决:我们自己给他带上,把URL重新写。 拼上一个JSESSIONID

                =session的ID。使用的是response.encodeURL()

                原来:http://localhost:8080/servletdemo/ServletDemo1

                重写后:http://localhost:8080/servletdemo/ServletDemo1;JSESSIONID=123

                注意:要重写必须全都重写,忘了一个,session中的数据就全部丢失。

                     因为不带cookie了,所以每次都是创建一个新的session

    7HttpSession对象的状态

        a、什么是持久态

            把长时间不用,但还不到过期时间的HttpSession进行序列化,写到磁盘上。

            我们把HttpSession持久态也叫做钝化。(与钝化想反的,我们叫活化。)

        b、什么时候使用持久化

            第一种情况:当访问量很大时,服务器会根据getLastAccessTime来进行排序,对长时间不用,但是还没到过期时间的HttpSession进行持久化。

            第二种情况:当服务器进行重启的时候,为了保持客户HttpSession中的数据,也要对HttpSession进行持久化

        d、注意:HttpSession的持久化由服务器来负责管理,我们不用关心。

                 只有实现了序列化接口的类才能被序列化,否则不行。

这篇关于Javaweb学习笔记5—CookieSession的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/662701

相关文章

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

SpringBoot中配置Redis连接池的完整指南

《SpringBoot中配置Redis连接池的完整指南》这篇文章主要为大家详细介绍了SpringBoot中配置Redis连接池的完整指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以... 目录一、添加依赖二、配置 Redis 连接池三、测试 Redis 操作四、完整示例代码(一)pom.

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析