热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:Java是如何读取和写入浏览器Cookies的

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器COOKIEs的相关的知识,希望对你有一定的参考价值。


首先我们认识下什么是COOKIEs:

COOKIE实际上是一个存在你硬盘里的数据,但是这些数据很特殊,只能由web应用提交给浏览器帮助存储,并且我们还能读取浏览器的COOKIE

web应用一般只在COOKIE中存储一些用户信息等少量且暂时的数据,数据量大则不适合存储在COOKIEs

 



 

一般浏览器对于每个web应用会分别给予他们40个COOKIE用来存储数据,并且每个COOKIE的大小不超过4K(听说部分浏览器的COOKIE能存很大的数据,不过我们一般不会存这么大的数据,因为数据提取的效率不高,影响性能)

说了这么多废话,然后重点终于来了

java通过httpServletRequest接口来访问浏览器请求中的COOKIEs数据(这里先了解一下COOKIEs来龙去脉,代码待会一并给出)

每个COOKIE有两个属性:键 ,值(无特定格式字符串,所以可以diy存数据,不过要注意URL编码问题,编码问题待会和代码一同讲)

如果我们需要存储新的COOKIE我们可以new一个COOKIE实例 并通过httpservletRsponse提交到浏览器,进而存储到本地

下面给出COOKIE的一个通用类

 


/*
* 该类可以从浏览器请求中提取出COOKIEs并进行对cookis的相关操作
*
*/
public class COOKIEsUtil extends BaseController {

/**
* 根据名字获取COOKIE
*
*
@param request
*
@param name
* COOKIE名字
*
@return
*/
public static COOKIE getCOOKIEByName(HttpServletRequest request, String name) {
Map
COOKIEMap = ReadCOOKIEMap(request);
if (COOKIEMap.containsKey(name)) {
COOKIE COOKIE
= (COOKIE) COOKIEMap.get(name);
return COOKIE;
}
else {
return null;
}
}
/**
* 将COOKIE封装到Map里面
*
*
@param request
*
@return
*/
private static Map ReadCOOKIEMap(HttpServletRequest request) {
Map
COOKIEMap = new HashMap();
COOKIE[] COOKIEs
= request.getCOOKIEs();
if (null != COOKIEs) {
for (COOKIE COOKIE : COOKIEs) {
COOKIEMap.put(COOKIE.getName(), COOKIE);
}
}
return COOKIEMap;
}
/**
* 保存COOKIEs
*
*
@param response
* servlet请求
*
@param value
* 保存值
*
@author jxf
*/
public static HttpServletResponse setCOOKIE(HttpServletResponse response, String name, String value,int time) {
// new一个COOKIE对象,键值对为参数
COOKIE COOKIE = new COOKIE(name, value);
// tomcat下多应用共享
COOKIE.setPath("/");
// 如果COOKIE的值中含有中文时,需要对COOKIE进行编码,不然会产生乱码
try {
URLEncoder.encode(value,
"utf-8");
}
catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
COOKIE.setMaxAge(time);
// 将COOKIE添加到Response中,使之生效
response.addCOOKIE(COOKIE); // addCOOKIE后,如果已经存在相同名字的COOKIE,则最新的覆盖旧的COOKIE
return response;
}

 

 

 

有了上面的通用类我们可以读取和新建COOKIE了,在这里我还要提一点:新建COOKIE的名字如果浏览器已经存在,则不再重复添加,会覆盖之前的COOKIE

 

浏览器如何查看请求的COOKIE和返回的COOKIE呢?拿Google浏览器举个栗子

技术分享

 

然后就是我们可能需要对COOKIE进行删除操作

 


1 /**
2 *

删除无效COOKIE


3 *

无效?1.过时 2.未发布


4 * @param request
5 * @param response
6 * @param list
7 */
8 private void delectCOOKIEByName(HttpServletRequest request, HttpServletResponse response,String deleteKey) throws NullPointerException {12 Map COOKIEMap = ReadCOOKIEMap(request);17 for (String key : COOKIEMap.keySet()) {
18 if(key==deleteKey && key.equals(deleteKey)) {
19 COOKIE COOKIE = COOKIEMap.get(key);21 COOKIE.setMaxAge(0);//设置COOKIE有效时间为0
22 COOKIE.setPath("/");//不设置存储路径
23 response.addCOOKIE(COOKIE);
24 }
25 }
26 }

 

注意删除COOKIE必须同时具备时间和路径的参数不然部分浏览器删除不了

最后,不得不提一下,写了这么,对你有用就给个赞!!!

 


推荐阅读
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • 本文将详细介绍通过CAS(Central Authentication Service)实现单点登录的原理和步骤。CAS由耶鲁大学开发,旨在为多应用系统提供统一的身份认证服务。文中不仅涵盖了CAS的基本架构,还提供了具体的配置实例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • XWiki 数据模型开发指南
    本文档不仅介绍XWiki作为一个增强版的wiki引擎,还深入探讨了其数据模型,该模型可在用户界面层面被充分利用。借助其强大的脚本能力,XWiki的数据模型支持从简单的应用到复杂的系统构建,几乎无需直接接触XWiki的核心组件。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • 本文介绍如何使用Java中的正则表达式来提取字符串中的特定值。通过示例代码和详细解释,帮助开发者掌握正则表达式的使用方法,尤其是如何匹配和提取复杂模式中的数据。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
author-avatar
多伦多打折优惠信息_205
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有