因为http协议是无状态的,也就是说每个客户端访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端状态。会话技术是帮助服务器记住客户端状态的。

一次会话的开始是通过浏览器访问某个站点,结束是关闭这个浏览器的过程。会话技术就是记录这次会话中客户端的状态哦与数据的。会话技术分为两种,分别是cookie和session。

  1. cookie:数据存储到客户端本地,减少了服务器的存储压力,但安全性不好,客户端可以手动清除cookie
  2. session:将数据存储到服务器,安全性相对较好,但与此同时增加了服务器自身的压力。

创建cookie:Cookie cookie = new Cookie("username","lisi");

将cookie发送到浏览器:response.addCookie(cookie);

cookie没有无参构造方法,且参数不能是中文。参数类型都是String,第一次设置cookie请求中不能看到,以后可以看到已设置的cookie,只要浏览器不关闭cookie依旧存在。

为cookie设置持久化时间:cookie信息在硬盘上保留的时间

cookie.setMaxAge(int seconds);例如:cookie.setMaxAge(10*60);设置时间为10分钟。

为cookie设置携带的路径:cookie.setPath("/web/sendCookie");当访问sendCookie 时才携带这个cookie。Cookie.setPath("/");访问服务器下的所有资源都携带这个cookie。

创建并发送cookie
//1.创建cookie对象
Cookie cookie=new Cookie("name","tian"); //2.携带这个cookie的资源路径
cookie.setPath("/cookie&session/sendServlet"); //3.设置cookie对象持久化时间1分钟
cookie.setMaxAge(60); //4,将cookie信息增加到客户端
response.addCookie(cookie);//name:"tian"

注意:如果不设置携带路径那么这个cookie信息会在访问产生该cookie的web 资源所在的路径都携带cookie信息。

删除客户端携带的cookie:

如果想删除客户端已存储的cookie信息那么就使用同名同路径的持久化时间为0的cookie进行覆盖即可。

删除指定的cookie

//1.找到同名的这个cookie,值可以不填
Cookie cookie=newCookie("name","");
//2.找到同路径下的cookie
cookie.setPath("/web/sendCookie/");
//3.将持久化时间设置0,删除成功
cookie.setMaxAge(0);

用cookie提示客户端上次访问的时间

在此遇到了一个异常:

java.lang.IllegalArgumentException: An invalid character [32] was present in the Cookie value

在Tomcat9.0运行出现的异常,解决方法:

Date date=new Date();

SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");

中间()内的时间格式不能含有空格,将空格去掉就行。

response.setContentType("text/html;charset=UTF-8");
Datedate=new Date();
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");
String lastTime = format.format(date); //1.第一次访问创建cookie
Cookie cookie=new Cookie("lastAccessTime",lastTime);
cookie.setMaxAge(60*100);//100minutes
response.addCookie(cookie);//添加到客户端 //2,要找到这个cookie并判断他的值是否为空,若为空显示这是第一次访问,若不为空显示上次访问时间
Cookie[] cookies = request.getCookies();
String lastAccessTime = null;
if(cookies!=null){
for(Cookie coo : cookies){
if(coo.getName().equals("lastAccessTime")){
lastAccessTime=coo.getValue();
}
}
} if(lastAccessTime!=null){
//不是第一次访问
response.getWriter().write("您上次访问的时间是:"+lastAccessTime);
}else{
response.getWriter().write("您是第一次访问这个页面!");
}

Session技术是将数据存储在服务器端的技术,会为每个客户端都创建一块内存空间    存储客户的数据,但客户端需要每次都携带一个标识ID去服务器中寻找属于自己的内   存空间。所以说Session的实现是基于Cookie,Session需要借助于Cookie存储客    户的唯一性标识JSESSIONID。

1. 获得Session对象

    HttpSession session = request.getSession();

此方法会获得专属于当前会话的Session对象,如果服务器端没有该会话的Session    对象会创建一个新的Session返回,如果已经有了属于该会话的Session直接将已有    的Session返回(实质就是根据JSESSIONID判断该客户端是否在服务器上已经存在    session了)

  2. 怎样向session中存取数据(session也是一个域对象)

Session也是存储数据的区域对象,所以session对象也具有如下三个方法:

  1. session.setAttribute(String name,Object obj);
  2. session.getAttribute(String name);
  3. session.removeAttribute(String name);

3.Session对象的生命周期

创建:第一次执行request.getSession()时创建

销毁:

  1. 服务器(非正常)关闭时
  2. session过期/失效(默认30分钟)
  3. 手动销毁session  session.invalidate();

问题:时间的起算点 从何时开始计算30分钟?

从不操作服务器端的资源开始计时,如果中间时间进行了操作那么就要重新计时

可以在工程的web.xml中进行配置

<session-config>

<session-timeout>30</session-timeout>

</session-config>

session.invalidate();

作用范围:

默认在一次会话中,也就是说在,一次会话中任何资源公用一个session对象

session的持久化,例如当我们创建一个servlet1,在servlet1中新见一个session,设置属性名和对应的值

session.setAttribute("name","jerry");
再建一个servlet2,在2中获取这个session对应的name值Jerry,当然是先访问1再访问2,当关闭浏览器时,再次打开访问2,得到的数据是null,因为session是基于cookie的,每次创建一个session会话,会得到一个jsessionid,客户端拿着这个id去找对应的session内存区域,但存储JSESSIONID的这个cookie默认是会话级别并没有设置持久化,所以当我们再次访问2的时候没有找到session内存区域,得到name对应的值是null,因此想要关闭浏览器后再次打开访问2得到值,可以将session持久化,方式如下:
@WebServlet("/sessionServlet1")
public class sessionServlet1 extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
} protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { HttpSession session = request.getSession();
String id = session.getId();
//将session持久化
Cookie cookie = new Cookie("JSESSIONID",id);
cookie.setPath("/cookie&session/");
cookie.setMaxAge(60*10);//设置时间10分钟
response.addCookie(cookie); response.getWriter().println(id);
session.setAttribute("name","jerry"); }
} @WebServlet("/sessionServlet2")
public class sessionServlet2 extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
} protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
String name = (String) session.getAttribute("name");
response.getWriter().println("name: "+name); }
}

cookie和session会话技术的更多相关文章

  1. Cookie与Session会话技术

    Cookie与Session会话技术 一.什么是会话 会话:当用户打开浏览器,访问多个WEB资源,然后关闭浏览器的过程,称之为一个会话,选项卡,弹出页面都属于这个会话,且共享同一个session. 二 ...

  2. Java开发系列-Cookie与Session会话技术

    概述 会话技术:当用户打开浏览器的时候,访问不同的资源,直到用户将浏览器关闭,可以认为这是一次会话.会话技术产生是由于Http请求是一个无状态的协议,它不会记录上次访问的内容,用户在访过程中难免产生一 ...

  3. 6.19-response(响应),session(会话技术,服务器端技术) 内置对象,application(内置对象),pageContext (内置对象),cookie(客户端技术)

    一.response(响应) 页面重定向 response.sendRedirect(""); 转发: request.getRequestDispatcher("&qu ...

  4. java web Session会话技术(原理图解+功能+与Cookie的区别+基本使用)

    java web Session会话技术(原理图解+功能+与Cookie的区别+基本使用) 这是我关于会话技术的第二篇文章,对 Cookie有不了解的兄弟可以点击下方的Cookie跳转 Cookie链 ...

  5. SESSION会话技术

    以下对session会话技术详解: 要了解点http协议理解更佳--->http请求头和http相应头 在session_start的时候,浏览器会向服务器发出请求 在请求的同时,如果是第一次a ...

  6. 16)用了session会话技术

    为什么用session会话技术? 因为假如你进入后台,不可能随意进入,即使你的验证通过了,那么还需要一个变量来存一个标志,假如标志的值是yes,那么我们可以直接进入后台的首页,无需验证,但是,标志是n ...

  7. Cookie&Session会话技术

    一.会话技术简介 1.存储客户端的状态 由一个问题引出今天的内容,例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客 ...

  8. springbootDay03 cookie和session 购物车技术

    一.会话技术 1. 什么是会话 在计算机术语中,会话指的是客户端和服务器交互通讯的过程.简单的理解,大家可以看成是两个普通的人在打电话.一次电话从通话开始到挂断,可以看成是会话. 会话的特征 会话能够 ...

  9. java 浅谈web系统当中的cookie和session会话机制

    一 Cookie: 1. Cookie翻译为小甜饼,有一种特殊的味道.cookie主要用来在(浏览器)客户端做记号用的.Cookie不属于java,Cookie是一种通用的机制,属于HTTP协议的一部 ...

随机推荐

  1. Codeforces Round #682 Div2 简要题解

    Contest link A.Specific Tastes of Andre Problem link 题意 构造一个长度为 \(n\) 的序列,使得每个非空子序列的和都被其长度整除. 思路 直接每 ...

  2. 【NOI2020】美食家(矩阵)

    Description 给定一张有向图,\(n\) 个顶点,\(m\) 条边.第 \(i\) 条边从 \(u_i\) 到 \(v_i\),走完该边的用时为 \(w_i\).每一个点有一个价值 \(c\ ...

  3. 题解-[SDOI2016]征途

    [SDOI2016]征途 [SDOI2016]征途 给定长度为 \(n\) 的序列 \(a\{n\}\),将其分为连续 \(m\) 段,和分别为 \(v\{m\}\).\(v\{m\}\) 的方差为 ...

  4. 关于C++的异常抛出

    在接触 throw 之前,我们只知道可以通过函数的返回值来获取和定位错误,比如通过 return 来层层返回是一种方法,但如果牵扯到多层函数调用,那么通过 return 来返回错误显得过于拖沓,这时就 ...

  5. sqli-labs less-24(二次注入)

    less-24 原理: 在网站处理用户提交的数据的时候,只是将某些敏感字符进行了转义.因而使得用户第一次提交的时候不会被当做代码执行.但是这些数据存入数据库的时候却没有转义,而网站程序默认数据库中的数 ...

  6. CSS-backgroound和radial-giadient的常见用法

    前言 这里主要介绍下css中background和radial-giadient径向渐变的使用,工作中用到的地方可能也不太多,但是每次用到了都需要查阅官网,查资料就比较麻烦,这里记录一下我自己整理的常 ...

  7. 【Tomcat 源码系列】Tomcat 整体结构

    一,前言 在开始看源码细节之前,首先要想好要看的问题.想好问题之后,我们该如何寻找要看的代码呢? 其实,这就好像去爬山的时候,突然想去上厕所,如果有一副地图,那么我们可以很快就找到厕所的位置.带着问题 ...

  8. 浅析JavaWeb开发模式:Model1和Model2

    一.前言 在学习JavaWeb的过程中,大家都会接触到Model1和Model2,历史的发展过程是Model1 → Model2.那么它们之间有何相同之处和不同之处呢? 二.Model1 Model1 ...

  9. Jetty web server 远程共享缓冲区泄漏漏洞学习

    https://www.secpulse.com/archives/4911.html https://www.tiejiang.org/11628.html http://blog.gdssecur ...

  10. 自适应查询执行:在运行时提升Spark SQL执行性能

    前言 Catalyst是Spark SQL核心优化器,早期主要基于规则的优化器RBO,后期又引入基于代价进行优化的CBO.但是在这些版本中,Spark SQL执行计划一旦确定就不会改变.由于缺乏或者不 ...