Cookie创建,回传,携带、Cookie案例(上次登录时间)、Session域值传递、Session持久化(购物例子)

本文主要是介绍Cookie创建,回传,携带、Cookie案例(上次登录时间)、Session域值传递、Session持久化(购物例子),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Cookie的创建,回传,携带
        //1、创建cookie对象Cookie cookie = new Cookie("name","zhangsan");//1.1 为cookie设置持久化时间 ---- cookie信息在硬盘上保存的时间cookie.setMaxAge(10*60);//10分钟 ---- 时间设置为0代表删除该cookie//1.2 为cookie设置携带的路径//注意:如果不设置携带路径,那么该cookie信息会在访问产生该cookie的    web资源所在的路径都携带cookie信息//cookie.setPath("/WEB16/sendCookie");//访问sendCookie资源时才携带这个cookiecookie.setPath("/WEB16");//访问WEB16下的任何资源时都携带这个cookie//cookie.setPath("/");//访问服务器下的所有的资源都携带这个cookie//2、将cookie中存储的信息发送到客户端---头response.addCookie(cookie);

在浏览器输入如下rul:
http://localhost:8080/WEB16/sendCookie
第一次请求如下:
这里写图片描述

第二次请求如下:
这里写图片描述

第一次请求url时候,没有返回cookie,response创建cookie,然后设置cookie有效期,进行回传,然后再次访问会携带cookie提交,cookie在浏览器关闭时候,cookie就失效了,因为cookie是会话级别的,由于这个cookie设置了有效期,返回cookie时候,存在了本地磁盘上,关闭浏览器,在此访问时候,依然有cookie携带过去

Cookie的失效
        //删除客户端保存 name=zhangsan的cookie信息Cookie cookie = new Cookie("name","");//将path设置成与要删除cookie的path一致cookie.setPath("/WEB16");//设置时间是0cookie.setMaxAge(0);response.addCookie(cookie);
获取请求中携带的cookie
        //获得客户端携带的cookie的数据Cookie[] cookies = request.getCookies();//Cookie cookie = new Cookie("name","zhangsan");//通过cookie名称获得想要的cookieif(cookies!=null){for(Cookie cookie : cookies){//获得cookie的名称String cookieName = cookie.getName();if(cookieName.equals("name")){//获得该cookie的值String cookieValue = cookie.getValue();System.out.println(cookieValue);}}}
Cookie例子–获取上次登录时间
    //获得当前时间Date date = new Date();SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");String currentTime = format.format(date);//1、创建Cookie 记录当前的最新的访问时间Cookie cookie = new Cookie("lastAccessTime",currentTime);cookie.setMaxAge(60*10*500);response.addCookie(cookie);//2、获得客户端携带cookie ---- lastAccessTimeString lastAccessTime = null;Cookie[] cookies = request.getCookies();if(cookies!=null){for(Cookie coo : cookies){if("lastAccessTime".equals(coo.getName())){lastAccessTime = coo.getValue();}}}response.setContentType("text/html;charset=UTF-8");if(lastAccessTime==null){response.getWriter().write("您是第一次访问");}else{response.getWriter().write("您上次的访问的时间是:"+lastAccessTime);}

思路如下:
将当前时间创建一个cookie,回传给浏览器,下次访问携带cookie,然后获取这个cookie,进而获取上次的时间,第一次访问url,是不携带cookie的,所以判断得出是第一次登录,下次访问就携带cookie,cookie带着时间值,然后显示上次登录的时间

Session域值传递

SessionServlet1

//创建属于该客户端(会话)的私有的session区域/* request.getSession()方法内部会判断 该客户端是否在服务器端已经存在session* 如果该客户端在此服务器不存在session 那么就会创建一个新的session对象* 如果该客户端在此服务器已经存在session 获得已经存在的该session返回*/HttpSession session = request.getSession();session.setAttribute("name", "jerry");String id = session.getId();//该session对象的编号idresponse.getWriter().write("JSESSIONID:"+id);

SessionServlet2

    //从session中获得存储的数据HttpSession session = request.getSession();Object attribute =  session.getAttribute("name");response.getWriter().write(attribute+"");

第一次访问SessionServlet1时,创建session,并且为session设值,为浏览器回传jSessionId(通过cookie的形式),然后在不关闭浏览器的前提下,进行访问SessionServlet2,这里会携带JsessionId,去获取session域设值的值


这里写图片描述

这里写图片描述

那么关闭浏览器再去访问SessionServlet2会出现null的情况,也就是获取不到session值
因为JSESSIONID cookie形式是会话级别的,关闭浏览器,cookie就消失了,访问SessionServlet2会创建一个新的SessionId

所以我们就得需要JsessionId持久化

Session持久化 (购物例子)
    //创建属于该客户端(会话)的私有的session区域/* request.getSession()方法内部会判断 该客户端是否在服务器端已经存在session* 如果该客户端在此服务器不存在session 那么就会创建一个新的session对象* 如果该客户端在此服务器已经存在session 获得已经存在的该session返回*/HttpSession session = request.getSession();session.setAttribute("name", "jerry");String id = session.getId();//该session对象的编号id//手动创建一个存储JSESSIONID的Cookie 为该cookie设置持久化时间Cookie cookie = new Cookie("JSESSIONID",id);cookie.setPath("/WEB16/");cookie.setMaxAge(60*10);response.addCookie(cookie);response.getWriter().write("JSESSIONID:"+id);

这篇关于Cookie创建,回传,携带、Cookie案例(上次登录时间)、Session域值传递、Session持久化(购物例子)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据