一、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. AdminLTE 前端框架

    适合运维平台  后台管理系统 AdminLTE 是一个开源的后台控制面板和仪表盘 WebApp 模板. 这是一个快速的HTML模板,基于CSS框架的引导. 文档: http://adminlte.la ...

  2. Python turtle绘制阴阳太极图代码解析

    本文详细分析如何使用Python turtle绘制阴阳太极图,先来分解这个图形,图片中有四种颜色,每条曲线上的箭头表示乌龟移动的方向,首先从中心画一个半圆(红线),以红线所示圆的直径作半径画一个校园, ...

  3. Java之指定Junit测试方法的执行顺序举例

    问题描述: 大家都知道使用JUnit进行测试的时候,方法的执行顺序不是按照编写的先后顺序执行的,那么如何控制Junit的执行顺序呢? 解决方法: 在测试类上加 @FixMethodOrder 注解即可 ...

  4. Lodop打印连续的纸张

    连续的纸张,有时有会被误解为没有高度,高度自适应,其实不是,这属于纸张连续打印,纸张高度和实际单个纸张高度相同.纸张高度自适应适用于没有高度的那种小票打印(卷纸没有纸张分界线),不是这种连续纸张.关于 ...

  5. codeforces545C

    Woodcutters CodeForces - 545C Little Susie listens to fairy tales before bed every day. Today's fair ...

  6. 实验吧 WEB 头有点大

    看到了良心的提示,http header,之后看到了要求.NET framework 9.9 英国 IE,我想想.NET好像还没有更新到9.9,就无视了这重要的提示. 我就看了一眼题解,发现burps ...

  7. Civil 3D 二次开发 新建CLR项目出现错误C2143

    新建CLR项目出现错误C2143 按照Objectarx Training创建.net混合项目,编译时出现一下错误: 原因不明: 解决方法: 在Stdafx.h文件中添加: #define WIN32 ...

  8. 微服务配合docker使用

    1.docker 安装 rabbitmq 启动脚本: docker run -d --name rabbitmq --publish : \ --publish : --publish : --pub ...

  9. 洛谷3705 [SDOI2017] 新生舞会 【01分数规划】【KM算法】

    题目分析: 裸题.怀疑$ O(n^4log{n}) $跑不过,考虑Edmonds-Karp优化. 代码: #include<bits/stdc++.h> using namespace s ...

  10. ☆ [HDU2089] 不要62「数位DP」

    类型:数位DP 传送门:>Here< 题意:问区间$[n,m]$的数字中,不含4以及62的数字总数 解题思路 数位DP入门题 先考虑一般的暴力做法,整个区间扫一遍,判断每个数是否合法并累计 ...