美文网首页java学习
NO.68 状态管理-cookie

NO.68 状态管理-cookie

作者: smallnumber | 来源:发表于2017-09-13 22:18 被阅读0次

(1)什么是状态管理?

将浏览器与web服务器之间多次交互当做一个整体来处理,并且

将多次交互所涉及的数据(即状态)保存下来。

(2)如何进行状态管理

1)将状态保存在客户端(浏览器)

Cookie

2)将状态保存在服务器端

session

(3)Cookie

1)什么是Cookie?

服务器临时存放在浏览器端的少量数据

2)工作原理

当浏览器访问服务器时,服务器会将少量数据发送给浏览器(使用set-cookie消息头),浏览器会将这些数据临时保存下来;

当浏览器再次访问服务器时,会将之前保存的数据发送给服务器(使用cookie消息头)。

3)添加cookie

Cookie c = new Cookie(String name,String value);

response.addCookie(c);

4)读取cookie

Cookie[] request.getCookies();

注:有可能返回null。

String cookie.getName();

String cookie.getValue();

5)编码问题

a. cookie只能保存合法的ascii字符,如果是中文,

需要将中文转换成合法的ascii字符串。

String URLEncoder.encode(String str,String charset);

String URLDecoder.decode(String str,String charset);

b.建议添加cookie时,都统一编码。

6)生存时间问题

a.默认情况下,浏览器会将cookie保存在内存里面。

只有浏览器不关闭,cookie就会一直保存,浏览器一关闭,cookie就会被删除。

b.cookie.setMaxAge(int seconds)

  注:b1. seconds单位是秒。

b2. 当seconds > 0时,浏览器会将cookie保存在硬盘上(文件的形式存放),超过指定时间,浏览器会销毁该cookie。

当seconds < 0时,默认值(即保存在内存里面)。

当seconds = 0时,删除cookie。

比如,要删除一个名称为username的cookie:

Cookie c  = new Cookie("username","");

c.setMaxAge(0);

response.addCookie(c);

7)cookie的路径问题

a.浏览器访问服务器时,会比较cookie的路径是否与要访问的路径匹配,只有匹配的cookie才会被发送。

b.cookie的默认路径

默认等于添加该cookie的web组件的路径。

比如  /servlet-day06/biz01/addCookie.jsp添加了一个cookie,则该cookie的默认路径就是

/servlet-day06/biz01

c.匹配规则

要访问的路径必须等于cookie的路径或者是其子路径,

符合该要求的cookie才会被发送出去。

比如,cookie的路径是  /servlet-day06/biz01,

  则:/servlet-day06/findCookie1.jsp  不会

/servlet-day06/biz01/findCookie2.jsp  会

/servlet-day06/biz01/sub/findCookie3.jsp  会

d.cookie.setPath(String path)

  注:该方法用于设置cookie的路径

8)cookie的限制

a.可以被用户禁止。

b.只能保存少量的数据(大约4k左右)。

c.保存的数量也有限制(大约几百个)。

d.只能保存字符串,对于中文,需要编码。

e.不安全。

相关文章

  • NO.68 状态管理-cookie

    (1)什么是状态管理? 将浏览器与web服务器之间多次交互当做一个整体来处理,并且 将多次交互所涉及的数据(即状态...

  • http特点

    优点 1、http是不保存状态的协议,使用cookie来管理状态(登录 先给cookie 先看有没有cookie)...

  • 图解HTTP--笔记5

    为 Cookie 服务的首部字段 Cookie 的工作机制是用户识别及状态管理。Web 网站为了管理用户的状态会通...

  • Http Cookie

    Cookie Cookie的作用是管理服务器端和客户端之间状态,工作机制是用户识别和状态的管理,Web网站为了管理...

  • Cookie&Token

    前言 http是无状态协议,需要cookie存储用户登录状态。cookie的工作机制是用户识别及状态管理。 服务器...

  • 状态管理一:cookie

    会话跟踪用来跟踪用户的整个会话,常用的技术是cookie和session。理论上,一个用户的所有请求操作都应...

  • 十、 状态管理--Cookie

    1. 现有问题 HTTP协议是无状态的,不能保存每次提交的信息 如果用户发来一个新的请求,服务器无法知道它是否与上...

  • 细读 JS | XSS、CSRF 浅谈

    一、前提 Cookie 常用于会话状态管理、个性化设置等。 在浏览器可以通过 document.cookie 来访...

  • HTTP使用Cookie管理状态

    HTTP是无状态协议,不对之前发生过的请求和响应的状态进行管理。也就是说,无法根据之前的请求对这次请求进行处理。 ...

  • 【HTTP 】是不保存状态的协议和 Cookie 的简单介绍

    HTTP 协议对于发送的请求和响应不做持久化处理。这时候引入了 Cookie 技术用于状态管理。Cookie 对用...

网友评论

    本文标题:NO.68 状态管理-cookie

    本文链接:https://www.haomeiwen.com/subject/ptzlsxtx.html