同源策略

本文探讨了在Struts2框架下,使用不同主机名访问同一应用时出现的Session丢失问题。具体表现为从localhost切换到127.0.0.1时,原先保存在Session中的用户信息变为null的现象,并解释了这是由Cookie的同源策略导致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

struts2编写一个程序,如果登陆界面使用localhost如下
http://localhost:8080/ElearningAdmin/login.jsp
之后将用户对象存入session中,然后到下个画面如:
http://localhost:8080/ElearningAdmin/show.jsp
从session中去对象没有问题,但是如果使用
http://127.0.0.1:8080/ElearningAdmin/show.jsp

则取到的session对象中的用户是null,为什么 ~ ~ ~ 


答:因为 Session ID 是记在 Cookie 中的,而 Cookie 存在一个限制,即同源策略。也就是说,Cookie 从客户端发送到服务端,只能是相同协议、相同域名、相同端口的 Cookie 数据才能被发送。

由于 http://localhost:8080 与 http://127.0.0.1:8080 的域名不同,所以在 localhost:8080 下产生的 Cookie 数据不会放在 127.0.0.1:8080 的请求头中去,因此服务端无法获取 Session ID 值,也就无法获取之前的 Session

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值