cookie取值域名设置java_Cookie设置域名问题,cookie跨域

本文探讨了在PHP中使用setcookie函数设置cookie时,如何通过domain参数控制cookie的作用域。通过实例展示了在不同域名下设置domain对cookie可用性的影响,强调了domain设置的两点关键注意事项:默认为当前域名,且不能设置为非父级或子域名。正确设置cookie的domain对于优化网站性能和保护用户资源至关重要。
摘要由CSDN通过智能技术生成

当我们给网站设置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下的所有子域名。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值