状态管理-Cookie
来源:互联网 发布:全排列的递归实现算法 编辑:程序博客网 时间:2024/06/05 10:48
状态管理
为什么需要状态管理?
- Web应用程序使用HTTP协议通信,而HTTP协议是“无状态”协议,即:服务器一旦响应完客户的请求之后,就断开连接,而同一个客户的下次请求将重新建立网络连接。
- 服务器应用程序有时是需要判断是否为同一个客户发出的请求,比如客户的多次选购商品。因此,有必要跟踪同一个客户发出的一系列请求。
什么是状态管理?
- 将客户端(浏览器)与服务器之间多次交互(一次请求,一次响应)当做一个整体来看待,并且将多次交互所涉及的数据即状态保存下来。
- 状态指的是数据。
- 管理指的是多次交互时对数据的修改。
状态管理的两种常见模式
- 客户端状态管理技术:将状态保存在客户端。代表性的是Cookie技术。
- 服务器状态管理技术:将状态保存在服务器端。代表性的是Session技术。
Cookie
什么是Cookie
- 浏览器向Web服务器发送请求时,服务器会将少量的数据以set-Cookie消息头的方式发送给浏览器,浏览器将这些数据保存下来;
- 当浏览器再次访问服务器时,会将这些数据以Cookie消息头的方式发送给服务器。
Cookie的原理
如何创建Cookie
- Servlet API为使用Cookie提供了javax.servlet.http.Cookie
- 创建:
Cookie c = new Cookie(String name,String value); response.addCookie(c);
- name:用于区分不同的Cookie的名字- value: Cookie的值
如何查询Cookie
- 获取客户端的所有Cookie对象:
Cookie[] request.getCookies();
注:该方法有可能返回null
- 获取一个Cookie对象的名称或值
String Cookie.getName(); String Cookie.getValue();
如何修改Cookie
- step1、获取客户端发送的所有Cookie
- step2、根据那么找到要修改的Cookie
- step3、调用Cookie的setValue(String newValue)方法修改该Cookie的值
- step4、将修改后的Cookie加入到response发送回客户端
- 【综上就是:增加一个与原Cookie名一样的Cookie来覆盖原来的Cookie,以达到修改的目的。】
Cookie[] Cookies = request.getCookies();if(Cookies != null){ for(Cookie c : Cookies){ String name = c.getName(); if(name.equals("city"){ c.setValue("shanghai"); response.addCookie(c);//同名Cookie会覆盖,以达到修改的目的 } }}
Cookie的生存时间
- 默认情况下,浏览器会将Cookie保存在内存中,只要浏览器不关闭,Cookie就一直存在
- 如果希望关闭浏览器后Cookie仍在,可以通过设置过期时间
void Cookie.setMaxAge(int seconds);
注:seconds单位是秒,精度不是很高 - seconds > 0 : 浏览器要保存Cookie的最长时间为设置的参数值,如果超过指定的时间,浏览器会删除这个Cookie。此时Cookie保存在硬盘上。
- seconds = 0:删除Cookie。在修改Cookie的生存时间为0后,随着response发送回客户端,替换原有Cookie,因生命周期到了即将把Cookie删除。
- seconds < 0:缺省值,浏览器会将Cookie保存到内存中。
Cookie编码
- Cookie 只能保存合法的ADSCII字符。如果要保存中文,需要将中文转换成合法的ASCII字符,即编码。
Cookie c = new Cookie("city",URLEncoder.encode("北京","utf-8"));
Cookie解码
- 编码后的Cookie为了看到实际的中文,需要还原后再显示
Cookie[] Cookies = request.getCookies();if(Cookies != null){ Cookie c = Cookies[0]; String value = c.getValue(); value = URLDecoder.decode(value,"utf-8");//与编码时格式保持一致}
Cookie的路径问题
什么是Cookie的路径问题
- 浏览器在访问服务器上的某个地址时,会比较Cookie的路径与该路径是否匹配,只有匹配的Cookie才会发送给服务器。
- Cookie的默认路径等于添加这个Cookie的Web组件的路径。
- 如:/appName/file/addCookie.jsp添加一个Cookie,则该Cookie的路径等于/appName/file
发送Cookie的条件
- 要访问的地址必须是Cookie的路径或者其子路径时,浏览器才会发送Cookie。
- 如:
- Cookie的路径是/appName/file
- 则访问/appName/file/a.jsp或/appName/file/b.jsp时会发送Cookie
- 如果访问/appName/c.jsp则不会发送Cookie
如何设置Cookie的路径
- 使用如下代码段可以设置Cookie的路径
Cookie c = new Cookie("uname","jack");c.setPath("/appName");response.addCookie(c);
Cookie的限制
- Cookie可以被用户禁止
- Cookie会将状态保存在浏览器端,不安全。对于敏感数据,需要加密后在使用Cookie来保存
- Cookie只能保存少量的数据,大约4kb左右
- Cookie的个数是有限制的
- Cookie只能保存字符串
0 0
- 状态管理-Cookie
- 状态管理-Cookie
- cookie状态管理
- 状态管理---cookie、session
- 状态管理--Cookie
- 状态管理-cookie
- 状态管理-cookie
- 状态管理之cookie详解
- JSP状态管理之cookie
- SERVLETJSP Unit06: 状态管理-cookie
- 状态管理——Cookie
- ASP.NET状态管理之五(Cookie)
- ASP.NET状态管理之一:Cookie
- JSP中使用cookie完成状态管理
- C#状态管理(Application、Session、Cookie)
- 深入剖析web的状态管理-Cookie
- ASP.NET 状态管理(cookie、Session)
- C#状态管理(Application、Session、Cookie)
- hdu 2612 Find a way
- 黑马程序员—Java基础(接口,类,抽象类综合小练习)
- Android平台开发-WIFI 驱动移植 -- 详细
- 一步一步教你做ios推送
- Mysql数据库安装和配置
- 状态管理-Cookie
- Python单例模式的4种实现方法
- 黑马程序员——C语言—结构体变量存储原理
- .net数据库迁移
- 学习android编程之路(1)— 环境变量配置
- 修改JAVA_HOME无效,java版本保持不变的问题解决
- 文件下载,带转码->pdf->swf
- ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源
- Kotlin在Android工程中的应用