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

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

go中的时间处理过程

《go中的时间处理过程》:本文主要介绍go中的时间处理过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 获取当前时间2 获取当前时间戳3 获取当前时间的字符串格式4 相互转化4.1 时间戳转时间字符串 (int64 > string)4.2 时间字符串转时间

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in