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


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。

 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM