cas登录传递的参数_cas自定义登录页面的提交按钮要怎么改
发布日期:2021-06-24 17:29:47 浏览次数:2 分类:技术文章

本文共 967 字,大约阅读时间需要 3 分钟。

AJAX:  熟悉 Ajax 的可能都知道,它的请求方式是严格按照沙箱安全模型机制的,严格情况下会存在跨域安全问题。

IFrames: 这也是早期的 ajax 实现方式,在页面中嵌入一个隐藏的IFrame,然后通过表单提交到该iframe来实现不刷新提交,不过使用这种方式同样会带来两个问题:

a.  登录成功之后如何摆脱登录后的IFrame呢?如果成功登录可能会导致整个页面重定向,当然你能在form中使

用属性target="_parent",使之弹出,那么你如何在父页面显示错误信息呢?

b.  你可能会受到布局的限止(不允许或不支持iframe)

对于以上两种方案,并非说不能实现,只是说对于一个灵活的登录系统来说仍然还是会存在一定的局限性的,我们坚信能有更好的方案来解决这个问题。

4. 通过JS重定向来获取login ticket (lt)

当第一次进入子系统的登录页时,通过 JS 进行redirect到cas/login?get-lt=true获取login ticket,然后在该login中的 flow 中检查是否包含get-lt=true的参数,如果是的话则跳转到lt生成页,生成后,并将lt作为该redirect url 中的参数连接,如 remote-login.html?lt=e1s1,然后子系统再通过JS解析当前URL并从参数中取得该lt的值放置登录表单中,即完成 lt 的获取工作。其中进行了两次 redirect 的操作。

5. 开始实践

首先,在我们的子系统中应该有一个登录页面,通过输入用户名和密码提交至cas认证中心。不过前提是先要获取到  login tickt id. 也就是说当用户第一次进入子系统的登录页面时,在该页面中会通过js跳转到 cas/login 中的获取login ticket. 在 cas/login 的 flow 中先会判断请求的参数中是否包含了 get-lt 的参数。

在cas的 login flow 中加入 ProvideLoginTicketAction 的流,主要用于判断该请求是否是来获取 lt,在cas-server端声明获取 login ticket action 类:

com.denger.sso.web.ProvideLoginTicketAction

转载地址:https://blog.csdn.net/weixin_34164146/article/details/112032292 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:java多线程为啥一直用的一个线程_【无法接受!!!】一个Java多线程的问题,颠覆了我多年的认知!...
下一篇:windows7安dns服务器_如何在windows7上面搭建一个DNS服务器

发表评论

最新留言

能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月06日 00时50分18秒