cas跨域单点登录原理_基于CAS的SSO单点登录-实现ajax跨域访问的自动登录

先补课,以下网址可以把CAS环境搭起来。

【问题背景】两个系统的整合就不说了,简单来说就是网页放在NginX上,但是ajax调用tomcat的API获取数据,其中tomcat段用CAS做身份认证。具体使用的是org.jasig.cas.client,配置会略有不同就不展开了。

【问题描述】ajax调用不允许跨域访问,如果在该容器中未CAS登陆(没有ticket)则会遇到以下错误。

XMLHttpRequest cannot load [CAS服务器地址] No ‘Access-Control-Allow-Origin‘ header is present on the requested resource. Origin [应用地址] is therefore not allowed access.

【非ajax请求具体的跳转请求】就是标准的跳转,不上图了:

请求1:http访问tomcat。结果:302重定向指向CAS服务器

请求2:访问CAS服务器,带上CASTGC。结果:302重定向指向tomcat并带上ticket

请求3:访问tomcat,带上ticket。结果:200返回资源

【ajax请求具体的跳转请求】:

请求1:ajax访问tomcat。结果:302重定向指向CAS服务器

请求2:访问CAS服务器,带上CASTGC。结果:200返回无内容,浏览器提示错误(chrome)

跨域访问规则Access-Control-Allow-Origin是在CAS服务器配置的,项目无法更改。

【参考的解决方法】

a.在session超时的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值