1.会话控制

Http协议   Http协议两个缺陷:

1.HTTP协议是纯文本的    2.HTTP协议是无状态的

服务器不能简单的通过HTTP协议来区分多次请求是否发自同一个用户    虽然通过HTTP协议不能区分不同请求是否来同一用户,但是我们实际生活却有这样的需求。

[1] Cookie

看电影

去电影院看电影时,检票人员是认票不认人。

电影院的运作流程     1.印刷电影票     2.将票发给看电影     3.看电影的拿着票来看电影     4.检票

简介

我们想可以通过服务器向浏览器发送一个类似票的东西,浏览器在访问服务器时就可以拿着票来访问,服务器就可以根据这个票来识别不同的用户。 服务器发送给浏览器的这张票我们称为Cookie。

Cookie的使用流程:

1.服务器先要创建Cookie     2.将Cookie发送给浏览器     3.浏览器带着Cookie访问服务器     4.服务器检查浏览器的Cookie

Cookie实际上就是一个头     服务器通过响应头将Cookie发送给浏览器, 浏览  器通过请求头将Cookie发回给服务器, 服务器可以根据不同的Cookie来识别不同的用户。

使用Cookie    - 创建Cookie     Cookie cookie = new Cookie(name,value);

发送Cookie      response.addCookie(cookie);     注意:可以发送多个cookie!         - 读取Cookie

request.getCookies(); 返回的是一个Cookie数组。

虽然Cookie是一个键值对结构,但是它并没有给咱们提供一个根据键获取值的方法。      我们要想读取Cookie的信息,只能通过遍历数组。

修改Cookie     一旦Cookie发给浏览器以后,服务器便不能直接修改Cookie, 但是可以通过使用同名Cookie来替换的老Cookie方式来间接的修改

Cookie的有效时间    - Cookie的默认有效时间为一次会话,当关闭浏览器时,Cookie将失效。

通过setMaxAge(秒数)来设置Cookie的有效时间    -//当秒数大于0时,有效时间会设置为相应的秒数     cookie.setMaxAg(30);

//当秒数等于0时,代表Cookie立即失效,浏览器不会保存。

cookie.setMaxAge(0);       //当秒数小于0时,和不设置是一样,一次会话中有效

cookie.setMaxAge(-100);         设置一个长久有效的Cookie     cookie.setMaxAge(60*60*24*365*10)      在程序中使Cookie立即失效

还可以使用一个同名的,立即失效的Cookie来替换已有Cookie

注意:不建议在cookie中传递中文,会用base64编码!

Cookie的Path    path指的Cookie的路径,所谓的Cookie路径就是指,浏览器在访问哪些地址时会携带Cookie。

Cookie默认有效路径是项目的根目录,只要访问当前项目下的资源就会带着Cookie,通过setPath()方法来设置Cookie有效路径

//修改Cookie的有效路径

//Cookie的路径由浏览器解析,所以设置路径时需要加上项目名

cookie.setPath(request.getContextPath()+"/hello");

应用:    1.可以用来保持用户的登录状态    2.可以用来记录用户上次输入的用户名        3.广告的推送

Cookie练习

模拟一个taobao的功能,保存用户输入用户名。

用户在login.jsp输入用户名和密码 , 请求发送个LoginServlet

LoginServlet收到请求行,检查用户名和密码是否正确。(默认登录成功)     如果正确,则将用户名保存到一个Cookie中,并发送给浏览器 ,重定向到 login-success.jsp     如果错误,转发到login.jsp

170814关于Cookie的知识点的更多相关文章

  1. cookie&session&servletContext

    一.cookie VS session 1)应用场景 cookie可以用于: 记录用户上次登录的时间 记住用户名和密码 session可以用于: 防止非法登录(即直接跳转到本来需登录验证方可登录的页面 ...

  2. 【转载】HTTP Cookie学习笔记

    什么是cookie? cookie是什么?是饼干,小甜点? No! No! No! 我今天要总结的cookie并不是你所想的小甜心,我这里要说的cookie是Web开发中的一个重要的"武器& ...

  3. django之模型层(model)--查询补充及cookie

    已经连续写了好几篇django的模型层(model)增删改查的随笔了,没篇大篇幅都是查询相关的操作,可以看出查询在数据的操作中是多么的重要,而本篇最后再补充一点关于关于查询的一些方法,模型层基本的操作 ...

  4. 67、django之模型层(model)--查询补充及mookie

    本篇导航: F查询与Q查询 cookie 一.F查询与Q查询 1.以Book表为例 class Book(models.Model) : title = models.CharField(max_le ...

  5. JSON Web Token 使用详解

    JWT 是什么? JSON Web Token(缩写 JWT)是目前最流行的跨域认证解决方案.它是有三部分组成,示例如下,具体的讲解如下(jwt 是不会有空行的,下面只是为了显示,便使用了换行看着比较 ...

  6. 2018-2019-2 网络对抗技术 20165322 Exp9 Web安全基础

    2018-2019-2 网络对抗技术 20165322 Exp9 Web安全基础 目录 实验内容与步骤 (一)Webgoat安装 (二)SQL注入攻击 1.命令注入(Command Injection ...

  7. 为什么你学不会递归?告别递归,谈谈我的一些经验 关于集合中一些常考的知识点总结 .net辗转java系列(一)视野 彻底理解cookie,session,token

    为什么你学不会递归?告别递归,谈谈我的一些经验   可能很多人在大一的时候,就已经接触了递归了,不过,我敢保证很多人初学者刚开始接触递归的时候,是一脸懵逼的,我当初也是,给我的感觉就是,递归太神奇了! ...

  8. 对EL自己以及对于param、header、cookie的相关应用的相关知识点的复习

    EL表达式语言是一种可以计算和输出的java对象的简单语言. 列入请求语句为下面的方式:request.setAttribute("username","zhangsan ...

  9. Cookie 知识点再整理

    1. Cookie  是存储在客户端 内存 或者 硬盘(例如火狐把 Cookie 存储在 C:\Documents and Settings\用户名\Application Data\Mozilla\ ...

随机推荐

  1. 我的常用的Linux命令

    环境:centos7 主要应用Linux命令是为了搭建环境,所以记录一下我的常用的Liunx命令 一.常用目录.文件操作命令 1.显示目录列表命令 ls       显示当前目录下的可见文件 ls - ...

  2. VS2008 项目启动时报:“无法直接启动带有类库输出类型的项目”

    解决办法一: 右击要解决方案项目--属性-通用属性—单启动项目 解决方法二:直接选中界面类,右击设为启动项目, 如果还是这样,那么在此项目上按右键 (VS2010的资源管理工具中),点属性,更改设置.

  3. web 前端3 javascript基础

    JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. 一.如何编写 1.J ...

  4. 版本控制工具 GIT 简要教程

    一,Git 简介 其实这个就不用说了 但是国际惯例还是介绍一下吧; Git 是一个开源的分布式版本控制系统,用于敏捷 高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助 ...

  5. ngnix高并发的原理实现(转)

    英文原文:Inside NGINX: How We Designed for Performance & Scale 为了更好地理解设计,你需要了解NGINX是如何工作的.NGINX之所以能在 ...

  6. git ssh key配置&解决git每次输入密码

    git ssh key配置&解决git每次输入密码:https://blog.csdn.net/qq_42817227/article/details/81415404

  7. BAT程序员常用的开发工具,建议收藏!

    今天给大家推荐一批 BAT 公司常用的开发工具,个个好用,建议转发+收藏. 阿里篇 一.Java 线上诊断工具 Arthas Arthas 是阿里巴巴 2018 年 9 月开源的一款 Java 线上诊 ...

  8. 中标麒麟系统安装rpm文件

    打开终端,获得su权限. cd到rpm所在文件夹,输入指令,rpm -ivh rpm的名称

  9. Python 中的垃圾回收机制

    GC作为现代编程语言的自动内存管理机制,专注于两件事:1. 找到内存中无用的垃圾资源 2. 清除这些垃圾并把内存让出来给其他对象使用.GC彻底把程序员从资源管理的重担中解放出来,让他们有更多的时间放在 ...

  10. 题解 P5265 【模板】多项式反三角函数

    →_→ OI 生涯晚期才开始刷板子题的咱 其实这题就是道公式题,搞过多项式全家桶的同学贴贴板子照着公式码两下都能过... 至于公式的证明嘛...总之贴上公式: \[Arcsin(F)=\int{F'\ ...