cas服务原理.docxVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、CAS服务端的处理逻辑 CAS服务端总共对外暴露了7个接口,客户端通过访问这7个接口与服务端交互,这7个接口为:/login、/logout、/validate、/serviceValidate、/proxy、/proxyValidate、/CentralAuthenticationService。/login是认证接口,/logout是退出接口,负责销毁认证cookie,/validate、/serviceValidate是验证ticket用的接口,其中/validate是CAS1.0定义的,/serviceValidate是CAS2.0定义的,其中/serviceValidate返回xml格式的数据,/proxy、/proxyValidate是支持代理认证功能的接口,/CentralAuthenticationService接口用于和远程的webservices交互。对于一般web应用的单点登录来讲,/login、/logout、/serviceValidate这3个接口已经可以满足要求。下面是我对CAS各个接口实现的的详细说明。 /login: 登录流程这部分要考虑到不同种类用户凭证的获取方案,以及客户应用传来的service、gateway、renew参数的不同取值组合,CAS为了实现流程的高度可配置性,采用了SpringWebFlow技术。通过阅读CAS发布包里的login-webflow.xml、cas-servlet.xml、applicationContext.xml这3个文件,找到登录有关的所有组件如下图: 注: 1:InitialFlowSetupAction:是流程的入口。用request.getContextPath()的值来设置cookie的Path值,Cookie的path值是在配置文件里定义的,但这个Action负责将request.getContextPath()的值设置为Cookie的path值,这是在cas部署环境改变的情况下,灵活地设置cookiepath的方式;把cookie的值以及service参数的值放入requestContext的flowscope里。 2:GenerateServiceTicketAction此Action负责根据service、GTCcookie值生成ServiceTicket对象,ServiceTicket的ID就是返回给客户应用的ticket参数,如果成功创建ServiceTicket,则转发到WarnAction,如果创建失败,且gateway参数为true,则直接redirect到客户应用,否则则需要重新认证。 3:viewLoginForm这是登录页面,CAS在此收集用户凭证。CAS提供的默认实现是/WEB-INF/view/jsp/simple/ui/casLoginView.jsp。 4:bindAndValidate对应AuthenticationViaFormAction的doBind方法,该方法负责搜集登录页面上用户录入的凭证信息(用户名、密码等),然后把这些信息封装到CAS内部的Credentials对象中。用户在casLoginView.jsp页面上点击提交后,会触发此方法。 5:submit对应AuthenticationViaFormAction的submit方法,如果doBind方法成功执行完,则触发submit方法,此方法负责调用centralAuthenticationService的grantServiceTicket方法,完成认证工作,如果认证成功,则生成TicketGrantingTicket对象,放在缓存里,TicketGrantingTicket的ID就是TGCCookie的value值。 6:warnCAS提供了一个功能:用户在一个web应用中跳到另一个web应用时,CAS可以跳转到一个提示页面,该页面提示用户要离开一个应用进入另一个应用,可以让用户自己选择。用户在登录页面viewLoginForm上选中了id=”warn”的复选框,才能开启这个功能。 WarnAction就检查用户有没有开启这个功能,如果开启了,则转发到showWarnView,如果没开启,则直接redirect到客户应用。 7:SendTicketGrantingTicketAction此Action负责为response生成TGCCookie,cookie的值就是AuthenticationViaFormAction的submit方法生成的TicketGrantingTicket对象的ID。 8:viewGenerateLoginSuccess这是CAS的认证成功页面。 /logout:(对应实现类org.jasig.cas.web.L

文档评论(0)

wei1155 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档