一、Cookie
    Cookie的数据是由客户端来保存和携带的,所以称之为客户端技术。
  1、属性:
    name:名称不能唯一确定一个Cookie。路径可能不同。
    value:不能存中文。
    path:默认值是写Cookie的那个程序的访问路径
      比如:http://localhost:8080/day10_00_cookie/servlet/ck1写的Cookie
        path就是:/day10_00_cookie/servlet 看当前创建cookie的资源(servlet)文件路径
          客户端在访问服务器另外资源时,根据访问的路径来决定是否带着Cookie到服务器
          当前访问的路径如果是以cookie的path开头的路径,浏览器就带。否则不带。

    maxAge:cookie的缓存时间。默认是-1(默认存在浏览器的内存中)。单位是秒。
      负数:cookie的数据存在浏览器缓存中
      0:删除。路径要保持一致,否则可能删错人。
      正数:缓存(持久化到磁盘上)的时间

二、HttpSession
  1、HttpSession定义
    > 它也是一个域对象: session servletContext request
    > 同一个会话下,可以使一个应用的多个资源共享数据
    > cookie客户端技术,只能存字符串。HttpSession服务器端的技术,它可以存对象。

  2、常用方法
    把数据保存在HttpSession对象中,该对象也是一个域对象。
    void setAttribute(String name,Object value);
    Object getAttribute(String name);
    void removeAttribute(String name);
    HttpSession.getId():

      setMaxInactiveInterval(int interval) 设置session的存活时间
      invalidate() 使此会话无效

  3、getSession():内部执行原理
      HttpSession request.getSession():内部执行原理
        1、获取名称为JSESSIONID的cookie的值。
        2、没有这样的cookie,创建一个新的HttpSession对象,分配一个唯一的SessionID,
          并且向客户端写了一个名字为JSESSIONID=sessionID的cookie
        3、有这样的Cookie,获取cookie的值(即HttpSession对象的值),

          从服务器的内存中根据ID找那个HttpSession对象:
          找到了:取出继续为你服务。
        找不到:从2开始。

    HttpSession request.getSession(boolean create):
      参数:
        true:和getSession()功能一样。
        false:根据客户端JSESSIONID的cookie的值,找对应的HttpSession对象,找不到返回null(不会创建新的,只是查询)。

  4、客户端禁用Cookie后的会话数据保存问题
    客户端禁用cookie:浏览器永远不会向服务器发送cookie的请求消息头

    解决方案:
      方案一:在主页上给出提示:请不要禁用您的cookie
      方案二:URL重写。必须对网站的所有地址都重写。

    http://url--->http://url;JSESSIONID=111

    response.encodeURL(String url);
      看浏览器有没有发送cookie请求消息头,没有就重写URL,有就不重写。

    request.getSession();必须写

coockie 和 session的更多相关文章

  1. session实现购物车

    为实现简单的购物功能(购物车添加.账户查看.购物车商品删除.实时的购物商品数量及价格的计算显示.购物车商品数量可手动输入等),用session实现了一简单的以php语言为基础.连接MySQL数据库的购 ...

  2. Asp.net Core中使用Session

    前言 2017年就这么悄无声息的开始了,2017年对我来说又是特别重要的一年. 元旦放假在家写了个Asp.net Core验证码登录, 做demo的过程中遇到两个小问题,第一是在Asp.net Cor ...

  3. 懒加载session 无法打开 no session or session was closed 解决办法(完美解决)

           首先说明一下,hibernate的延迟加载特性(lazy).所谓的延迟加载就是当真正需要查询数据时才执行数据加载操作.因为hibernate当中支持实体对象,外键会与实体对象关联起来.如 ...

  4. 探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)

    其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...

  5. Nhibernate的Session管理

    参考:http://www.cnblogs.com/renrenqq/archive/2006/08/04/467688.html 但这个方法还不能解决Session缓存问题,由于创建Session需 ...

  6. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

  7. zookeeper源码分析之六session机制

    zookeeper中session意味着一个物理连接,客户端连接服务器成功之后,会发送一个连接型请求,此时就会有session 产生. session由sessionTracker产生的,sessio ...

  8. [转载]Cookie/Session的机制与安全

    Cookie和Session是为了在无状态的HTTP协议之上维护会话状态,使得服务器可以知道当前是和哪个客户在打交道.本文来详细讨论Cookie和Session的实现机制,以及其中涉及的安全问题. 因 ...

  9. 修改session垃圾回收几率

    <?php //修改session垃圾回收几率 ini_set('session.gc_probability','1'); ini_set('session.gc_divisor','2'); ...

随机推荐

  1. NLP的原理,框架及具体实例

    1. 什么是NLP 所谓NLP就是自然语言处理,即计算机识别人的自然沟通语言,将人的语言转换成表达含义相同的文字.因为NLP的目的是将人和计算机通过自然语言沟通成为可能,而人最方便的沟通是通过语音发声 ...

  2. 一、.NET Core MVC 项目结构模板

    一.图文描述,开口干 二.文件结构:  wwwroot 首先,Razor Pages项目中多了一个wwwroot的文件夹,这个文件夹中,主要存放网站的静态资源,如css,网站图片资源文件,js文件,三 ...

  3. Python——Flask框架——程序的基本结构

    一.安装 pip install flask 二.初始化 from flask import Flask app = Flash(__name__) 三.路由:处理URL和函数之间的关系的程序称为路由 ...

  4. Spring Boot 构建电商基础秒杀项目 (七) 自动校验

    SpringBoot构建电商基础秒杀项目 学习笔记 修改 UserModel 添加注解 public class UserModel { private Integer id; @NotBlank(m ...

  5. spawn

    转载:http://motioo.blog.163.com/blog/static/117718291200954102830215/ 并行计算使用的节点数在开始运行程序时进行指定. 学习了FFT之后 ...

  6. poj2186(tarjan缩点)

    题意:有n头奶牛,假如奶牛A觉得奶牛B很厉害,那么就有一条由A指向B的边,然后有个传递关系,if(A→B,B→C,那么A→C),让你求出被除了自己以外所有的奶牛都认为厉害的的奶牛个数: 解题思路:看到 ...

  7. CentOS安装、配置Nginx反向代理

    添加Nginx存储库 sudo yum install epel-release 安装Nginx sudo yum install nginx 启动Nginx sudo systemctl start ...

  8. Cash Machine POJ - 1276 多重背包二进制优化

    题意:多重背包模型  n种物品 每个m个  问背包容量下最多拿多少 这里要用二进制优化不然会超时 #include<iostream> #include<cstdio> #in ...

  9. BZOJ 1977 严格次小生成树(算竞进阶习题)

    树上倍增+kruskal 要找严格次小生成树,肯定先要找到最小生成树. 我们先把最小生成树的边找出来建树,然后依次枚举非树边,容易想到一种方式: 对于每条非树边(u,v),他会与树上的两个点构成环,我 ...

  10. 爬虫_电影天堂 热映电影(xpath)

    写了一天才写了不到100行.不过总归是按自己的思路完成了 import requests from lxml import etree import time BASE = 'http://www.d ...