今天遇到了Cookie的问题,网上搜来些资料,记录一下备忘!
正常的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)设置多个域的方法???
最近的工作经常用到cookie,看了一些资料,虽然原来依赖cookie比较多的方案已经改成现在这个了,但是当时看得一些东西还是最好
记下来,免得过些天就一干二净了,怪可惜的。老梁说过这样的文字最好不要是纯文本的,说得是。本来就已经很抽象了,最好弄点图表,就算用123列出来也好。
相关推荐
5. 共享Cookie跨域 要实现不同域名下的网站共享Cookie,可以在设置Cookie时使用`setDomain()`方法,如`.wangwz.com`。这样,任何以`wangwz.com`为顶级域名的子域名都能访问这些Cookie。示例如下: ```java Cookie ...
1、设置Cookie的路径为setPath("/") .即Tomcat的目录下都有效 2、设置Cookie的域setDomain(".itcast.com");即bbs.itcast.com,或是mail.itcast.com有效。即跨域。 3、设置Cookie的时间。即使用户不选择在几天内自动...
- 设置路径,确保与要删除的 Cookie 的路径相同:`cookie.setPath("/test/test2");` - 将此 Cookie 添加到响应中,客户端接收到后会删除对应的 Cookie:`response.addCookie(cookie);` 4. **修改 Cookie** - ...
- 指定Cookie的作用路径,如`cookie.setPath("/test/test2")`,这样只有在指定路径下的请求才能访问到该Cookie。如果不设置,默认为当前请求的路径。 - 最后,通过`response.addCookie(cookie)`将Cookie添加到响应...
- **路径和域**:`setPath()`用于指定Cookie的作用路径,通常设置为应用的根路径;`setDomain()`用于指定Cookie的有效域名。 - **安全性和HTTPOnly**:`setSecure()`用于标记Cookie是否仅通过HTTPS传输,提高安全...
`Cookie`类还有其他一些重要的属性,如`setMaxAge(int seconds)`用于设置Cookie的生命周期(以秒为单位),`setPath(String path)`用于指定Cookie的作用路径,`setDomain(String domain)`用于设置Cookie的适用域名...
比如,`setPath(Cookie cookie, String path)` 和 `setDomain(Cookie cookie, String domain)` 方法。 8. **安全性和HTTP Only**: 对于敏感信息,通常会设置Cookie的“secure”标志,确保它只在HTTPS连接上传输。...
cookie.setPath("/"); cookie.setDomain(".example.com"); cookie.setMaxAge(60 * 60); // 1小时后过期 ``` 2. **添加Cookies到HTTP请求**: 当发送HTTP请求时,可以使用`HttpURLConnection`或`HttpClient`...
1. **设置Cookie路径**:为了使Cookie在整个Tomcat目录下有效,需要设置Cookie的路径为`setPath("/")`。这确保了在同一个Web服务器下的所有应用都可以读取和写入该Cookie。 2. **设置Cookie的域**:通过`setDomain...
设置Cookie的路径为`setPath("/")`,使其在整个Tomcat目录下有效。 2. 设置Cookie的域为`setDomain(".example.com")`,使得该Cookie可以在所有`.example.com`下的二级域名中有效。 3. 修改主机文件(例如Windows...
1. **设置Cookie的路径**:通过设置`setPath("/")`,确保Cookie在Tomcat的所有目录下都有效。例如,如果一个用户在一个子应用中登录了,那么在其他子应用中也能识别这个登录状态。 2. **设置Cookie的域**:通过设置...
- **路径与域名**:`setPath()`方法用于指定Cookie的作用路径,通常设置为应用程序的根路径("/"),这样整个应用都能访问到。`setDomain()`方法可以设置Cookie作用的域名,允许跨子域共享。 以上就是Java中读取和...