解决cas中cookie跨域,导致TGC丢失的问题

本文分析了CAS单点登录过程中,由于Cookie跨域导致TGC(Ticket Granting Cookie)丢失的问题。根本原因是客户端和服务端的域不一致。解决方案是通过nginx反向代理,使它们处于同一域下,从而确保TGC被正确记录。经过配置和测试,问题得到解决。
摘要由CSDN通过智能技术生成

解决cas中cookie跨域,导致TGC丢失的问题

问题表现

基于上一篇cas搭建后测试以及问题引出后,基本可以实现单点登录了,但是你如果去校验下整个单点登录的流程,你自然的会发现cas服务端创建的TGC的cookie并没有保存在浏览器中,这是有问题的。下面,让我们一起来重现这个问题。
为了测试,我准备了一个cas客户端以及cas服务端。
第一步,cas客户端测试页面http://localhost:8081/gateway/login,cas客户端检测到没有授权,cas客户端会构建单点登录授权的url,重定向到cas server进行登录授权,如图所示:
在这里插入图片描述
我们输入正确的账密进行登录,cas服务认证通过后,会重定向到客户端的页面,如图所示:
在这里插入图片描述
从图上的调试页面,可以看出cookie中并没有保存TGC,但cas server确实创建了TGC。造成此问题的主要原因是,cookie跨域了,导致TGC丢失了。

根本原因

我们访问客户端的链接为http://localhost:8081/gateway/login, 那cookie的域就是http:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值