控制 Cookie 的作用范围

      默认时,网站的所有 Cookies 都一起被存储在客户端,并且所有 Cookies同网站的任何请求一起被发送到服务器。换句话说,网站中的每个页面都能够为网站获取所有的Cookies。但是,你能够通过两个方式来设置 Cookies 的作用范围:
 把 Cookies 的作用范围限制到服务器的目录,从而允许你把 Cookies 限制到网站的某个应用程序。
设置域的作用范围,能够允许你指定域中的哪些子域能够访问 Cookie。
把 Cookies 限制到目录或应用程序
要把 Cookies 限制到服务器的目录,请设置 Cookie 的 Path 属性,如下实例所示:
HttpCookie appCookie = new HttpCookie("AppCookie");
appCookie.Value = "written " + DateTime.Now.ToString();
appCookie.Expires = DateTime.Now.AddDays(1);
appCookie.Path = "/Application1";
Response.Cookies.Add(appCookie);
提示:你同样可以通过直接添加到 Cookies 集合的方式来写入 Cookies,如前面的实例所示。
路径既能够位于网站的物理根目录中也能够位于虚拟根目录中。结果将会是 Cookie 只对于目录或者虚拟根 Application1 中的页面可用。例如,如果你的网站名称是 www.contoso.com,在前面的实例中所创建的 Cookie 将只对于路径 http://www.contoso.com/Application1/ 以及其下所有子目录中的页面可用。但是,该 Cookie 对于其他应用程序(如 http://www.contoso.com/Application2/ 或者 http://www.contoso.com/)中的页面则是不可用的。
提示:部分浏览器中的路径对大小写字母是敏感的。你无法控制用户如何在他们的浏览器中输入 URL,但是如果你的应用程序依赖于 Cookies 来约束特定的路径,请确保你所创建的任何超级链接中的 URL 能够与 Path 属性值中的大小写相匹配。
限制 Cookie 的域范围
默认时,Cookies 是与特定的域相关联的。例如,如果你的网站是 www.contoso.com,你写入的 Cookies 会在用户从网站中请求任何页面的时候被发送到服务器。(可能不包括有特定的路径值的 Cookies。)如果你的网站中还拥有子域(例如,contoso.com、sales.contoso.com、以及 support.contoso.com),那么你可以把特定的子域与 Cookies 相关联。要这样做,请设置 Cookie 的 Domain 属性,如实例所示:
Response.Cookies["domain"].Value = DateTime.Now.ToString();
Response.Cookies["domain"].Expires = DateTime.Now.AddDays(1);
Response.Cookies["domain"].Domain = "support.contoso.com";
当按照这样设置域之后,Cookie 将只对于特定域中的页面可用。你同样能够使用 Domain 属性来创建一个能够在多个子域之间被共享的 Cookie,如下实例所示:
Response.Cookies["domain"].Value = DateTime.Now.ToString();
Response.Cookies["domain"].Expires = DateTime.Now.AddDays(1);
Response.Cookies["domain"].Domain = "contoso.com";
Cookie 这时候将与 sales.contoso.com 和 support.contoso.com 域一样对于主域是可用的。
在java中是怎么应用的呢?(如csdn上的2周内不用再登录是怎么实现的呢)
Cookie cName = new Cookie("username",signon.getUsername());
   Cookie cPassword = new Cookie("password",signon.getPassword());
   cName.setMaxAge(36000000);//这个很重要
   cPassword.setMaxAge(36000000);//这个很重要
   cName.setPath("/Shopping"); 
   cPassword.setPath("/Shopping");
   response.addCookie(cName);
   response.addCookie(cPassword);
而在页面中:
function readCookie(name)//利用javascript来读取客户端中cookie的值
{
  var cookieValue = "";
  var search = name + "=";
  if(document.cookie.length > 0)
  { 
    offset = document.cookie.indexOf(search);
    if (offset != -1)
    { 
      offset += search.length;
      end = document.cookie.indexOf(";", offset);
      if (end == -1) end = document.cookie.length;
      cookieValue = unescape(document.cookie.substring(offset, end))
    }
  }
  return cookieValue;
}
function initialize(){
 document.getElementById('signon.username').value=readCookie('username');//初始化对应的textfield
 document.getElementById('signon.password').value=readCookie('password'););//初始化对应的textfield

}
### Cookie 的作用域定义及其有效范围设置 在 Web 开发中,Cookie 是一种用于存储客户端状态的小型数据片段。它们通常由服务器发送到浏览器,并通过 `Set-Cookie` 响应头进行配置[^1]。为了控制 Cookie 的可见性和生命周期,开发者可以指定其 **作用域** 和其他属性。 #### 1. Cookie 的作用域概念 Cookie 的作用域决定了它可以在哪些路径和域名下被访问。这主要涉及两个关键参数: - **Domain**: 定义了 Cookie 可以生效的域名范围。如果未显式设置,则默认为当前页面所在的主机名(不包括子域名)。 - **Path**: 定义了 Cookie 可以生效的具体路径。如果没有特别设定,默认值为创建该 Cookie 的请求 URI 路径的一部分[^2]。 当浏览器接收到带有这些参数的响应时,会依据 Domain 和 Path 来判断何时向服务器发送对应的 Cookie 数据。 #### 2. 设置 Cookie 的有效范围 以下是具体说明如何通过 HTTP 头部或编程方式来设置 Cookie 的作用域: ##### (1)通过 Set-Cookie 响应头部设置 下面是一个典型的 `Set-Cookie` 示例: ```http Set-Cookie: sessionId=abc123; Domain=example.com; Path=/admin; HttpOnly; Secure ``` 在此例子中: - `sessionId=abc123`: 表示键名为 `sessionId`,值为 `abc123`。 - `Domain=example.com`: 将此 Cookie 的适用范围扩展至整个 `example.com` 域名及其所有子域名(如 `sub.example.com`),除非设置了更严格的规则。 - `Path=/admin`: 此 Cookie 仅限于 `/admin` 或者任何以 `/admin` 开始的路径上可用。 - `HttpOnly`: 防止 JavaScript 访问Cookie,从而减少 XSS 攻击风险。 - `Secure`: 确保 Cookie 仅能通过 HTTPS 协议传输。 ##### (2)通过编程接口动态设置 大多数现代框架都提供了便捷的方法来管理 Cookies。例如,在 Java Spring Boot 中可以通过以下代码实现自定义设置: ```java import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletResponse; public void setCustomCookie(HttpServletResponse response) { Cookie cookie = new Cookie("userId", "98765"); cookie.setDomain(".example.com"); // 应用于 example.com 及其子域名 cookie.setPath("/profile"); // 限定只在 /profile 下可读写 cookie.setMaxAge(60 * 60); // 生命周期设为一小时 cookie.setHttpOnly(true); cookie.setSecure(true); response.addCookie(cookie); } ``` 上述方法同样适用于其他语言环境下的开发工作流,比如 Python Flask/Django、Node.js Express 等。 #### 3. 特殊注意事项 - 如果希望某个 Cookie 对全站通用而不限定特定目录,只需将其 Path 属性置为空字符串或者根路径 (`/`)。 - 当跨多个子域共享同一组认证信息时,务必合理规划 Domain 参数;否则可能导致权限混乱甚至安全漏洞发生。 --- ### 总结 通过对 Cookie 的 Domain 和 Path 进行精确调整,能够有效地管理和优化用户的浏览体验同时保障安全性。以上介绍涵盖了基本原理以及实际操作中的最佳实践方案。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值