`

跨域共享Cookies

阅读更多
跨域共享Cookies

正常的cookie只能在一个应用中共享,即一个cookie只能由创建它的应用获得。
1.可在同一应用服务器内共享方法:设置cookie.setPath("/");
    本机tomcat/webapp下面有两个应用:cas和webapp_b,
    1)原来在cas下面设置的cookie,在webapp_b下面获取不到,path默认是产生cookie的应用的路径。
    2)若在cas下面设置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的cas应用也不可以。
    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的应用cas下面获取cookie了
    6)有多条cookie.setPath("XXX");语句的时候,起作用的以最后一条为准。
    6)设置多个path的方法???

2.跨域共享cookie的方法:设置cookie.setDomain(".jszx.com");
    A机所在的域:home.langchao.com,A有应用cas
    B机所在的域:jszx.com,B有应用webapp_b
    1)在cas下面设置cookie的时候,增加cookie.setDomain(".jszx.com");,这样在webapp_b下面就可以取到cookie。
    2)这个参数必须以“.”开始。
    3)输入url访问webapp_b的时候,必须输入域名才能解析。比如说在A机器输入:http://lc-bsp.jszx.com:8080/webapp_b,可以获取cas在客户端设置的cookie,而B机器访问本机的应用,输入:http://localhost:8080/webapp_b则不可以获得cookie。
    4)设置了cookie.setDomain(".jszx.com");,还可以在默认的home.langchao.com下面共享。
    5)设置多个域的方法???




1.设置Cookie
  Cookie cookie = new Cookie("key", "value");  
 
  cookie.setMaxAge(60);  
  设置60秒生存期,如果设置为负值的话,则为浏览器进程Cookie(内存中保存),关闭浏览器就失效。
  cookie.setPath("/test/test2");  
  设置Cookie路径,不设置的话为当前路径(对于Servlet来说为request.getContextPath() + web.xml里配置的该Servlet的url-pattern路径部分)
  response.addCookie(cookie);  
2.读取Cookie
  该方法可以读取当前路径以及“直接父路径”的所有Cookie对象,如果没有任何Cookie的话,则返回null
  Cookie[] cookies = request.getCookies();  
3.删除Cookie
  Cookie cookie = new Cookie("key", null);  
 
  cookie.setMaxAge(0);  
  设置为0为立即删除该Cookie
  cookie.setPath("/test/test2");  
  删除指定路径上的Cookie,不设置该路径,默认为删除当前路径Cookie
  response.addCookie(cookie);  
4.修改Cookie
Cookie[] cookies=request.getCookies();  
 
if(cookies.length>1){  
      for(int i=0;i<cookies.length;i++){  
           if(cookies[i].getName().equals("key")) {  
             String oldValue = cookies[i].getValue();  
 
             String newValue=  "newValue";  
 
             cookies[i].setValue(newValue);  
             response.addCookie(cookies[i]);  
 
            break;  
            }  
       }              
   }  
===============================================================
实例:
1.实现两个网站www.ajava.org和ask.ajava.org共用Cookies
2.添加Cookies
Cookie cookie = new Cookie("name", "ajava");  
cookie.setPath("/");//这个要设置  
cookie.setDomain(".ajava.org");//这个也要设置才能实现上面的两个网站共用  
cookie.setMaxAge(365*24*60*60);//不设置的话,则cookies不写入硬盘,而是写在内存,只在当前页面有用,以秒为单位  
response.addCookie(cookie);  
cookie = new Cookie("nick", URLEncoder.encode("王伟宗","UTF-8"));  
cookie.setPath("/");  
cookie.setDomain(".ajava.org");  
cookie.setMaxAge(365*24*60*60);  
response.addCookie(cookie); 

3.获取cookies
Cookie cookies[] = request.getCookies();  
if (cookies != null)  
{  
    for (int i = 0; i < cookies.length; i++)  
     {  
        if (cookies[i].getName().equals("nick"))  
         {  
             System.out.println(URLDecoder.decode(cookies[i].getValue(),"UTF-8"));  
         }  
     }  


4.删除cookies
Cookie cookies[] = request.getCookies();  
if (cookies != null)  
{  
    for (int i = 0; i < cookies.length; i++)  
     {  
        if (cookies[i].getName().equals("nick"))  
         {  
             Cookie cookie = new Cookie("nick","");//这边得用"",不能用null  
             cookie.setPath("/");//设置成跟写入cookies一样的  
             cookie.setDomain(".ajava.org");//设置成跟写入cookies一样的  
             response.addCookie(cookie);  
         }  
     }  

========================================================
应用实例
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.util.*" errorPage="" %> 
<%@ page import="java.net.URLDecoder" %>   //注意导入此包  
 
<%  
Cookie cookie=new Cookie("hi","welcome");  
response.addCookie(cookie);  
Cookie[] cookies=request.getCookies();  
if(cookies!=null){  
for(int i=0;i<cookies.length;i++){  
if(cookies[i].getName().equals("hi")){  
String cookieValue=URLDecoder.decode(cookies[i].getValue(),"utf-8");  
out.print("hi="+cookieValue);  
}  
}  
}else{  
out.print(" no cookie");  
}  
%> 
注意:假设路径结构如下
  test/test2/test345/test555/test666
  a.相同键名的Cookie(值可以相同或不同)可以存在于不同的路径下。
  b. 删除时,如果当前路径下没有键为"key"的Cookie,则查询全部父路径,检索到就执行删除操作(每次只能删除一个与自己最近的父路径Cookie)   FF.必须指定与设定cookie时使用的相同路径来删除改cookie,而且cookie的键名不论大写、小写或大小混合都要指定路径。IE.键名小写时,如果当前路径为/test/test2,如果找不到再向上查询/test、/test555、/test345,如果还找不到就查询/(/test555/test666不查询) 。键名大小写混合或大写时,不指定路径则默认删除当前路径,并且不向上查询。
  c.读取Cookie时只能读取直接父路径的Cookie。如果当前路径为/test/test2,要读取的键为“key”。当前路径读取后,还要读取/test,/test读取后,还要读取/ 。
  d.在做Java的web项目时,由于一般的Web服务器(如Tomcat或Jetty)都用Context来管理不同的Web Application,这样对于每个Context有不同的Path,在一个Server中有多个Web Application时要特别小心,不要设置Path为/的Cookie,容易误操作(当然前提是域名相同) 。



参考:
1.跨域访问js:http://hi.baidu.com/eecc00/item/7c99477420e9f1345c1789e3
分享到:
评论

相关推荐

    二级域名或跨域共享Cookies的实现方法

    本文将详细解释如何在ASP环境中实现二级域名或跨域共享Cookies。 首先,了解Cookies的基本概念。Cookies是由服务器发送到用户的浏览器并存储在本地的一小段文本信息,它可以帮助服务器识别用户身份,维持会话状态等...

    主题:javascript最全的10种跨域共享的方法.docx

    【标题】:JavaScript中最全面的10种跨域共享技术详解 在JavaScript和其他客户端编程语言中,同源策略是保障网络安全的重要机制。它规定,来自不同源(协议、域名或端口不同)的脚本之间不能互相访问对方的大部分...

    javascript插件 解决双向跨域问题

    然而,有时我们需要在不同的域之间进行数据交换,例如API调用或共享cookies,这时就需要解决跨域问题。本文将深入探讨JavaScript插件如何解决双向跨域问题,并通过具体的插件实例——jcrossdomain,来阐述其实现方式...

    Spring boot 和Vue开发中CORS跨域问题解决

    如文章内容中所展示的CustomCORSConfiguration类示例,这个类通过配置CORS Filter来允许所有的源、方法和头信息进行跨域交互,并且支持凭证(cookies)的发送。 ```java @Configuration public class ...

    tomcat支持跨域jar.zip

    Tomcat可以通过修改`web.xml`文件来配置CORS(Cross-Origin Resource Sharing,跨源资源共享)过滤器。CORS是一种W3C标准,允许浏览器和服务器通过添加特定的HTTP头部来安全地执行跨域请求。 1. **添加CORS Filter*...

    Ext.Ajax.request跨域

    要使用Ext.Ajax.request进行跨域,你需要在请求配置中添加`withCredentials`属性(表示是否携带cookies)以及`headers`字段。例如: ```javascript Ext.Ajax.request({ url: 'http://other-origin.com/api', ...

    ajax跨域解决办法

    6. **Domain属性(仅限子域)**:在cookies中设置`domain`属性可以实现跨子域共享,但这仅限于同一主域下的子域名之间,对AJAX跨域请求帮助有限。 在实际应用中,开发者通常根据项目需求和服务器环境选择合适的跨域...

    cors技术解决ajax跨域

    若不需要跨域请求携带cookies或其他认证信息,可设置`Access-Control-Allow-Credentials`为`false`。 总之,CORS通过在服务器端设置特定的响应头,使浏览器能够判断并处理跨域请求,从而解决了AJAX的跨域问题。在...

    .net WebUploadTest实现跨域浏览

    - 使用jQuery的`$.ajax`或者fetch API创建一个跨域POST请求,设置`xhrFields`的`withCredentials`属性为true,以便发送cookies进行身份验证: ```javascript $.ajax({ url: 'http://yourserver.com/upload', ...

    geoserver跨域解决包

    "cors.zip"可能是包含解决跨域问题所需配置的压缩文件,CORS(Cross-Origin Resource Sharing,跨源资源共享)是一种机制,允许Web服务器通过设置特定的HTTP头来放宽同源策略的限制。"解决文档.txt"则很可能是详细...

    jQuery跨域问题

    3. CORS与IFrame:有时我们需要在不同的源之间共享cookies,这时可以使用IFrame和CORS结合的方式。jQuery可以通过在IFrame中嵌入跨域的页面,然后通过`window.postMessage` API进行通信,达到跨域的目的。 4. XHR ...

    spring cloud gateway跨域实现

    这个配置允许了所有来源("*")的跨域请求,支持GET、POST、PUT、DELETE、OPTIONS方法,并且允许发送Authorization头,并设置了允许携带cookies。 请注意,实际生产环境中,通常需要根据具体安全策略来调整CORS配置...

    geoserver cors跨域

    在开发Web应用程序并与GeoServer交互时,可能会遇到CORS(跨源资源共享)的问题。CORS是一种安全机制,用于规范浏览器如何处理来自不同源的请求,特别是JavaScript发起的Ajax请求。 标题“geoserver cors跨域”指的...

    完全跨域SSO

    4. **跨域问题**:在完全跨域SSO中,由于浏览器的同源策略限制,我们不能直接在后台共享cookies。解决方案通常有几种:CORS(跨源资源共享)、JSONP(JSON with Padding)或使用iframe和postMessage API来实现通信。...

    BrouzieCrossdomainAuthBundle:Symfony2的跨域身份验证捆绑包

    在Web应用开发中,特别是涉及到前后端分离或者API接口的场景,跨域资源共享(CORS,Cross-Origin Resource Sharing)成为一个重要的议题。这个捆绑包为开发者提供了一种安全且方便的方式来管理跨域身份验证。 **...

    JAVA前后台跨域的两种方法(详细步骤)

    在现代Web开发中,跨域资源共享(CORS)是一个常见的需求,特别是在使用JavaScript进行前后端分离的架构下。本文将详细介绍两种在JAVA后台处理跨域问题的方法,以便于前端和后端之间的数据交互。 方法一:CORS ...

    http cookies

    随着隐私保护意识的增强,一些替代技术应运而生,如Local Storage、Session Storage和IndexDB,它们提供了更大的存储空间,但不支持跨域共享,且不具备自动发送给服务器的功能。 ### 7. 开发者管理 在Web开发中,...

    WebClient跨域上传

    7. 跨域资源共享(CORS)的预检请求(Preflight Request):对于某些复杂请求,如PUT、DELETE或自定义HTTP头,浏览器会先发送一个OPTIONS请求到服务器,询问是否允许跨域请求。服务器需要正确响应预检请求,返回允许...

    tomca设置跨域.rar

    在现代Web开发中,跨域资源共享(CORS)是一个常见的需求,特别是在前后端分离的架构中。本资源“tomca设置跨域.rar”提供了一种使用Tomcat服务器配置跨域的方法,以及可能需要的依赖包。以下是关于Tomcat设置跨域的...

Global site tag (gtag.js) - Google Analytics