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

相关文章

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望... 目录前言一、consul是什么?二、安装运行consul三、使用1、服务发现2、配置管理四、数据持久化总

Spring 中使用反射创建 Bean 实例的几种方式

《Spring中使用反射创建Bean实例的几种方式》文章介绍了在Spring框架中如何使用反射来创建Bean实例,包括使用Class.newInstance()、Constructor.newI... 目录1. 使用 Class.newInstance() (仅限无参构造函数):2. 使用 Construc

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

Python如何获取域名的SSL证书信息和到期时间

《Python如何获取域名的SSL证书信息和到期时间》在当今互联网时代,SSL证书的重要性不言而喻,它不仅为用户提供了安全的连接,还能提高网站的搜索引擎排名,那我们怎么才能通过Python获取域名的S... 目录了解SSL证书的基本概念使用python库来抓取SSL证书信息安装必要的库编写获取SSL证书信息

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员