1. 从浏览器获取:使用javax.servlet.http.HttpServletRequest获取Cookie数组,通过Cookie名称找出所需的Cookie值。
Cookie[] cookies = request.getCookies();
2. 写入浏览器:使用javax.servlet.http.HttpServletResponse的addCookie()方法。将new出来的Cookie写入浏览器。
response.addCookie(cookie);
3. Cookie的重要属性分析。
domain: 默认值为当前项目所在的域名(或ip)。注意域名的格式是(点号+上一级域名)必须以“."点开始的(localhost除外)。domain决定了能够读取本Cookie的域名,即request只能读取它所在项目的域名,而不可跨域读和写Cookie。因此,如果你想读取别人的Cookie是不可能的,你想恶意删除别人的Cookie也是不可能的,至少浏览器是这么做的;否则,你就只能绕过浏览器,直接对Cookie文件进行操作。
path: 指定域中能够读取此Cookie的路径,默认值为"/"。此路径对其子路径是可视的,即包括子路径请求的request也可以读取此Cookie。
maxAge: 生命期,单位为秒。当值<0,表示浏览器关闭时自动删除,session应该就是这么使用Cookie的;当值=0,表示直接删除Cookie(将response将Cookie写入浏览器时替换同名Cookie,然后马上自我删除),此值用于删除Cookie。
secure: 表示Cookie是否加密,这取决于请求url是http还是https(SSL),一般会使用request.isSecure()方法的返回值来判断。
4. 问题分析:对于每个Web Server,浏览器最多支持200个Cookie、限制每个大小为4kb,但最好使用20个左右。Cookie在浏览器中返回时,是通过HTTP请求头传回到服务器的,故使用request获取的Cookie,实际上是从request.getHeader("cookie")头信息的cookie项中取出来的。所以,cookie值中存在特殊符号时,Cookie直接通过getValue()获取cookie值只是其中一部分,这时就应该想办法从header中解析出完整的Cookie值来。
(1) 如何删除浏览器中的Cookie?
Cookie cookie = new Cookie(cookieName,"");
cookie.setDomain("localhost");
cookie.setPath("/"); //注意路径正确。
cookie.setMaxAge(0); //0表示直接删除,负数表示当浏览器关闭时自动删除
response.addCookie(cookie);
(2) 如何取出带特殊符号(如“@”、“=”等符号,多数是由加密、编码之后产生的)的Cookie值?
String cookiesStr = request.getHeader("cookie");
//用于盛放Cookie名值对
Map<String,String> cookieMap = new HashMap<String,String>();
if(null != cookiesStr){
String[] cookies = cookiesStr.split(";");
int pos;
String name;
String value;
for(String cookie : cookies){
pos = cookie.indexOf("=");
//'='不能没有,也不能是第一个字母,更不能是最后一个字母
if(pos > 0 && pos < cookie.length()-1){
name = cookie.substring(0, pos).trim(); //分隔符";"有空格
value = cookie.substring(pos + 1).trim();
cookieMap.put(name, value);
}
}
}
分享到:
相关推荐
### Extjs 中关于 Cookie 的操作 #### 一、引言 在 Web 开发中,Cookie 是一种常用的数据存储方式,用于保存用户的一些基本信息或者状态,从而实现网站的个性化设置或登录状态保持等功能。Extjs 作为一种强大的 ...
关于Cookie有效期.txt
这是php中的一个关于cookie 的应用,在php中传入cs的变量值
Java小技巧:关于Cookie的操作.txt
在JavaScript中,Cookie是用于在用户浏览器中存储小量数据的一种机制。它们是HTTP协议的一部分,主要用于跟踪用户会话、存储用户首选项或保存登录状态。Cookie由服务器生成,并通过HTTP响应头发送到浏览器,浏览器在...
ppt介绍了cookie的基本知识,cookie欺骗产生的原理,跨站脚本攻击盗取Cookie,以及Cookie的安全对策
此外还可以直接通过`header()`函数发送`Set-Cookie`响应头来设置Cookie。 ##### 使用`setcookie()`函数 `setcookie()`函数的基本语法如下: ```php bool setcookie ( string $name [, string $value [, int $...
标题中的“cookie”一词指的是Web...以上是关于Cookie技术的基本介绍,具体实现细节和使用技巧可能需要参考原文档或“cookie.jsp”文件的内容。对于开发者来说,理解和熟练使用Cookie是构建高效、安全的Web应用的基础。
标题“使用Cookie记录用户名和密码”涉及到的是Web开发中的用户会话管理技术,特别是关于Cookie的应用。Cookie是一种在客户端和服务器之间传递信息的小型文本文件,常用于保持用户登录状态、存储用户偏好设置等。在...
8. **教育功能**:Cookie Pal还可能包含关于Cookie工作原理、隐私风险以及如何安全使用网络的教育资源,帮助用户提升网络安全意识。 了解并掌握Cookie Pal的使用,不仅有助于提升在线浏览的安全性和效率,还能让...
在Web开发中,数据存储是不可或缺的一部分,尤其是...对于学习和实践,"CookieTest"这个文件名可能包含了一些关于Cookie测试的代码示例,通过查看和分析这些代码,可以进一步加深对Cookie和localStorage的理解和运用。
用户可以访问该网站获取更多关于Cookie管理和清理的资源和信息。 6. **注意事项**: - 清理Cookie可能会影响某些网站的正常功能,如自动登录、购物车状态等。 - 不是所有Cookie都是有害的,适度管理以平衡便利性...
在Java编程中,Cookie是一种非常重要的技术,它用于在客户端和服务器之间传递信息,尤其是在实现用户会话管理、个性化设置等方面。...通过不断实践和深入学习,开发者可以掌握更多关于Cookie和Web开发的高级技巧。
今天有同事又问起关于cookie的问题,我就到网上查询了一下做了一些相关的摘要记录下来,以备不时之用。关于cookie的操作,做为JS程序员应该是相对熟悉一些的,所以就不对它进行过多的说明了。 以下就是关于各...
ISAPI开发者需要理解HTTP协议,特别是关于Cookie的规范,以便正确地设置和读取Cookie。 在实际开发中,除了基本的Cookie操作,还可能需要处理其他复杂情况,如处理多个Cookie、考虑安全性(如防止跨站脚本攻击XSS)...
在Spring Boot应用中,登录验证通常涉及到Cookie和Session两种技术,它们都是用于用户身份验证和会话管理的重要手段。本文将深入探讨如何在Spring Boot中使用Cookie和Session进行登录后的拦截处理。 首先,简单介绍...
**关于Cookie的解释**: Cookie,通常称为"小甜饼",是由服务器发送到用户的浏览器并存储在本地的一小段文本数据。它们被用来追踪用户的在线行为,比如保持登录状态、记录购物车内容或者个性化网站体验。第一方...
关于Cookie的设置,Cookie是Web服务器存储在用户浏览器中的小数据块,常用于会话管理、个性化设置等。当处理跨域请求时,有些情况下可能需要传递Cookie。默认情况下,浏览器只会发送同源的Cookie。如果需要在跨域...
"cookie_demo2.zip"这个压缩包文件似乎包含了一个关于Cookie使用的示例,特别是关注于Cookie的生命周期。接下来,我们将深入探讨Cookie、Session以及它们生命周期的相关知识点。 **1. Cookie的基本概念** Cookie是...
Cookie是Web应用程序中用于管理用户会话和存储用户...通过深入阅读“Cookie相关PDF文档”,你可以获得关于Cookie的全面理解,包括其工作原理、最佳实践、安全考虑和隐私法规,以及如何在实际项目中有效地应用Cookie。