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

相关文章

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

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

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

springboot security验证码的登录实例

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