1. 程式人生 > >cookie 跨域的問題

cookie 跨域的問題

weight 註意 摘錄 ref 二級域名 secure style bool cookie

今天研究一天發現cookie無法設置除當前域名或者其父域名之外的其他domain.

這個是瀏覽器出於對cookie的保護造成的,也就是cookie無法跨域設置。

對於子域名也有如下規則,當前域名只能設置當前域名以及他的父域名,不能設置子域名

如在www.wo.cao.baidu.com 域名下只能設置 cao.baidu.com,baidu.com

不能設置 da.jia.wo.cao.baidu.com的cookie。

一篇文章還不錯,摘錄下來

當我們給網站設置cookie時,大家有沒有發現在網站的其他域名下也接收到了這些cookie。這些沒用的cookie看似不占多少流量,但如果對一個日PV千萬的站點來說,那浪費的資源就不是一點點了。因此在設置cookie時,對它的作用域一定要設置準確了。

我們都知道在PHP中用setcookie 來設置網站的cookie,該函數的用法如下:

bool setcookie ( string $name [, string $value [, int$expire = 0 [, string$path [, string $domain [, bool$secure = false [, bool$httponly = false ]]]]]] )

今天我們就來探討一下它的第五個參數$domain,因為它決定了cookie的作用域。

現在有如下3個域名,一個頂級域名、一個二級域名和一個三級域名:

① zydya.com
②blog.zyday.com
③one.blog.zyday.com

  • 首先在①zyday.com域名下設置cookie,做四次測試,分別設置domain參數為空、‘zyday.com‘、‘blog.zyday.com‘與‘one.blog.zyday.com‘。
    √表示該域名下能取到cookie,×表示不能取到cookie
domain參數 zydya.com blog.zyday.com one.blog.zyday.com
setcookie(‘name‘,1,time()+1)
setcookie(‘name‘,1,time()+1,‘/‘,‘zyday.com‘)
setcookie(‘name‘,1,time()
+1,‘/‘,‘blog.zyday.com‘)
× × ×
setcookie(‘name‘,1,time()
+1,‘/‘,‘one.blog.zyday.com‘)
× × ×

當domain設置為空時,domain默認為當前域名,並且該域名下的子域名都可以接收到cookie。
但是domain參數設置其子域名時,所有域名就接收不到了,包括那個子域名。

  • 然後在②blog.zyday.com域名下設置cookie,測試條件同上
domain參數 zydya.com blog.zyday.com one.blog.zyday.com
setcookie(‘name‘,1,time()
+1)
×
setcookie(‘name‘,1,time()+1,‘/‘,‘zyday.com‘)
setcookie(‘name‘,1,time()+1,‘/‘,‘blog.zyday.com‘) ×
setcookie(‘name‘,1,time()+1,‘/‘,one.blog.zyday.com‘) × × ×

看第二行,domain參數是zyday.com,是blog.zyday.com的父域名,那麽zyday.com下所有子域名(包括zyday.com、blog.zyday.com、one.blog.zyday.com)都能接收到cookie。
當domain為自身域名時,那麽其父域名受影響,其本身與其子域名可以接收到cookie。
而設置其子域名或其他域名時,所有域名都接收不到cookie了。

  • 最後在③one.blog.zyday.com域名下設置cookie
domain參數 zydya.com blog.zyday.com one.blog.zyday.com
setcookie(‘name‘,1,time()
+1)
× ×
setcookie(‘name‘,1,time()+1,‘/‘,‘zyday.com‘)
setcookie(‘name‘,1,time()+1,‘/‘,‘blog.zyday.com‘) ×
setcookie(‘name‘,1,time()+1,‘/‘,one.blog.zyday.com‘) × ×

第三個測試得出的結論在上面已經總結了。再看一遍,這裏就不多解釋了。

domain的設置,有兩點要註意:

1.在setcookie中省略domain參數,那麽domain默認為當前域名。

2.domain參數可以設置父域名以及自身,但不能設置其它域名,包括子域名,否則cookie不起作用。

那麽cookie的作用域:

cookie的作用域是domain本身以及domain下的所有子域名。

本文來自 小菜鳥czh 的CSDN 博客 ,全文地址請點擊:https://blog.csdn.net/czhphp/article/details/65628977?utm_source=copy

cookie 跨域的問題