cookie用法小结 cookie.setPath 跨域共享

news/2024/5/18 16:39:38 标签: cookie

1. JSP中Cookie的读写

Cookie的本质是一个键值对,当浏览器访问web服务器的时候写入在客户端机器上,里面记录一些信息。Cookie还有一些附加信息,比如域名、有效时间、注释等等。

下面是一个jsp中写入读取Cookie的测试:在顶级域名中写入Cookie,在子域名中读取,目的是实现一个分布系统的单点登录。

两个jsp中读写代码如下:

写入:

<% 
Cookie cookie = newCookie("write","cookie_write"); 
cookie.setComment("这是一个Cookie写入测试!"); 
cookie.setVersion(100); 
cookie.setMaxAge(3600); 
cookie.setDomain(".iisp.com"); 
response.addCookie(cookie); 

%>

读取

<% 
Cookie cookies[]=request.getCookies(); 
out.println(" cookie的数量为:"+ cookies.length); 
out.println("<br>"+"<br>"); 
for(inti = 0;i<cookies.length;i++){ 
out.println("getName="+cookies[i].getName()+"<br>"); 
out.println("getValue="+cookies[i].getValue()+"<br>"); 
out.println("getComment="+cookies[i].getComment()+"<br>"); 
out.println("getDomain="+cookies[i].getDomain()+"<br>"); 
out.println("getPath="+cookies[i].getPath()+"<br>"); 
out.println("getMaxAge="+cookies[i].getMaxAge()+"<br>"); 
out.println("getVersion="+cookies[i].getVersion()+"<br>"); 
out.println("getSecure="+cookies[i].getSecure()+"<br>"); 
out.println("<br>"+"<br>"); 

%> 

测试结果表明:Cookied的写入读取均没有问题,并且Cookie的访问和域名有密切关系。子域名下可以读取到上级域名的Cookie。而不能读取到其他域名下的Cookie。

 

2.javax.servlet.http.Cookie有两个比较重要的方法:setDomain()、setPath()

正常的cookie只能在一个应用中共享,即一个cookie只能由创建它的应用获得。

1.可在同一应用服务器内共享方法:设置cookie.setPath("/"); 
本机tomcat/webapp下面有两个应用:webapp_a和webapp_b, 
1)原来在webapp_a下面设置的cookie,在webapp_b下面获取不到,path默认是产生cookie的应用的路径。

2)若在webapp_a下面设置cookie的时候,增加一条cookie.setPath("/");或者cookie.setPath("/webapp_b/");
就可以在webapp_b下面获取到cas设置的cookie了。

3)此处的参数,是相对于应用服务器存放应用的文件夹的根目录而言的(比如tomcat下面的webapp),因此cookie.setPath("/");之后,可以在webapp文件夹下的所有应用共享cookie,而cookie.setPath("/webapp_b/");
是指cas应用设置的cookie只能在webapp_b应用下的获得,即便是产生这个cookie的webapp_a应用也不可以。

4)设置cookie.setPath("/webapp_b/jsp")或者cookie.setPath("/webapp_b/jsp/")的时候,只有在webapp_b/jsp下面可以获得cookie,在webapp_b下面但是在jsp文件夹外的都不能获得cookie

5)设置cookie.setPath("/webapp_b");,是指在webapp_b下面才可以使用cookie,这样就不可以在产生cookie的应用webapp_a下面获取cookie

6)有多条cookie.setPath("XXX");语句的时候,起作用的以最后一条为准。

3.跨域共享cookie的方法:设置cookie.setDomain(".xxx.com");
例如在www.a.com下面写了一个Cookie["www.a.com"],在域名www.b.cn中如何访问Cookie["www.a.com"]呢?

通常,cookie却不能跨越域传递,只有那些创建它的域才能访问,同一根域名下的二级域名,三级域名可以直接共享。但你可以利用重定向来间接的获取cookies。

 


http://www.niftyadmin.cn/n/1622364.html

相关文章

SpringMvc三大组件详解

SpringMvc框架结构图 处理器映射器&#xff1a;用户请求路径到Controller方法的映射处理器适配器&#xff1a;根据handler(controlelr类&#xff09;的开发方式&#xff08;注解开发/其他开发&#xff09; 方式的不同区寻找不同的处理器适配器 视图解析器&#xff1a;根据handl…

solr报index locked for write for 的错误及解决办法

问题描述&#xff1a; 在虚拟机上正常配置好了solrhome及/tomcat/webapps/WEB-INF的web.xml文件后。web.xml配置如下&#xff1a;去掉注释后&#xff0c;添加solrhome <env-entry> <env-entry-name>solr/home</env-entry-name> <env-entry…

浏览器访问solr报错:HTTP Status 500 - {msg=SolrCore ‘collection1‘ is not available due to init failure: Inde

报错详细信息: org.apache.solr.common.SolrException: SolrCore collection1 is not available due to init failure:Index locked for write for core collection1 at org.apache.solr.core.CoreContainer.getCore(CoreContainer.java:753) at org.apache.sol…

Maven的安装及修改为阿里云下载依赖

使用JAVA工程管理越来越多的jar包&#xff0c;担心导错了&#xff0c;多导了&#xff0c;漏导了怎么办&#xff1f; 换一个IDE项目后项目会不会出一堆BUG&#xff0c;看的头皮发麻&#xff1f; 自己写的代码放在别人的机器上运行会不会出问题&#xff1f; Maven的强大毋庸置…

在maven工程中构建自己的第一个SpringBoot项目时,pom.xml中的<parent>报错

问题描述&#xff1a; 之前的maven仓库是在做“淘淘商城”时&#xff0c;跟着老师的步骤做的。现在在学习SpringBoot&#xff0c;创建第一个SpringBoot的maven工程时&#xff0c;pom文件的<parent>报错如下&#xff1a; Description Resource Path Location …

Spring、SpringBoot、SpringCloud还是傻傻分不清?

去年&#xff0c;花了几十元买了个SpringMVCSpringMybatis的课程&#xff0c;顺便发到了朋友圈里&#xff0c;这时有个前同事评论&#xff0c;现在都什么年代了&#xff0c;还学Spring框架&#xff0c;Spring早就过时了&#xff0c;现今流行SpringBoot和SpringCloud的&#xff…

Mybatis和JDBC区别

今天面试中问了这个问题&#xff0c;当时答的不好&#xff0c;现在整理一下。 JDBC是Java提供的一个操作数据库的API&#xff1b; MyBatis是一个支持普通SQL查询&#xff0c;存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果…

深入浅出MyBatis:JDBC和MyBatis介绍

最近在休陪产假&#xff0c;时间比较零碎&#xff0c;准备看2本书充实下&#xff0c;一本是「深入浅出MyBatis&#xff1a;技术原理与实践」&#xff0c;一本是「RabbitMQ实战&#xff1a;高效部署分布式消息队列」&#xff0c;为了加深记忆和理解&#xff0c;会进行整理、扩展…