分为三个部分
1、Cas服务器(用于验证用户是否正确)
       1、用户信息存在服务端,其它客户端应用程序修改用户信息后需要同步到服务端
       2、用户信息一般存储在服务端的数据库中,加密及验证算法Cas提供默认方法
2、Cas客户端(和应用程序合为一体)
3、客户端(一般是用户使用的web浏览器)
 
名词解释
1、ST:Server Ticket(就是Ticket)
    ST是CAS为用户签发的访问某一service的票据。用户访问service时,service发现用户没有ST,则要求用户去CAS获取ST。用户向CAS发出获取ST的请求,如果用户的请求中包含cookie,则CAS会以此cookie值为key查询缓存中有无TGT,如果存在TGT,则用此TGT签发一个ST,返回给用户。用户凭借ST去访问service,service拿ST去CAS验证,验证通过后,允许用户访问资源。
 
2、TGC:Ticket Granted Cookie  (客户端用户持有,传送到服务器,用于验证)
    存放用户身份认证凭证的cookie,在浏览器和CAS Server间通讯时使用,并且只能基于安全通道传输(Https),是CAS Server用来明确用户身份的凭证。
 
3、TGT(Ticket Grangting Ticket)
     TGT是CAS为用户签发的登录票据,拥有了TGT,用户就可以证明自己在CAS成功登录过。TGT封装了Cookie值以及此Cookie值对应的用户信息。用户在CAS认证成功后,CAS生成cookie(叫TGC),写入浏览器,同时生成一个TGT对象,放入自己的缓存,TGT对象的ID就是cookie的值。当HTTP再次请求到来时,如果传过来的有CAS生成的cookie,则CAS以此cookie值为key查询缓存中有无TGT ,如果有的话,则说明用户之前登录过,如果没有,则用户需要重新登录。
 
 
Cas客户端主要的几个Filter
      1、AuthenticationFilter
a)验证session是否有值(用户数据放在session中)
b)验证是否有ticket(不验证其正确性)
 
 
2、TicketValidationFilter
          a)验证ticket是否正确
          b)ticket只是用一次
3、AssertionThreadLocalFilter
          a) AssertionThreadLocalFilter作用很简单,就是将Assertion绑定到ThreadLocal
          c) 项目中可获取userInfo、roleInfo并存储在session中(从assertion中获取loginName)
4、单点登录(SingleSignOutFilter、SingleSignOutHttpSessionListener)
           a)功能:登录过滤器、监听器
           b) 先执行:SingleSignOutFilter-->doFilter()-->recordSession SingleSignOutHandler-->recordSession  ()

1、从request中获取token,key值为:"ticket"  
     这个Ticket只有在第一次跳转到本应用时才有值,以后取值都为null,以后进入其他页面时
  SingleSignOutFilter.doFilter()不再执行相关业务逻辑,而是直接执行后续的Filter
2、移除session:this.sessionMappingStorage.removeBySessionById(session.getId());
3、添加session、mapping、sessionId关系

     ID_TO_SESSION_KEY_MAPPING.put(session.getId(), mappingId);  //这里理解为存储sessionId和ST(mappingId)的对应关系
     MANAGED_SESSIONS.put(mappingId, session);   //这里理解为ST(mappingId)和session的对应关系

c)再执行SingleSignOutHttpSessionListener-->sessionCreated() 不做任何处理

d)单点登录添加Session
    1、mappingId参数:从request.getParameter("ticket"),为ST
    2、session参数:从request.getSession(true)获取
    3、HashMapBackedSessionMappingStorage-->addSessionById(String mappingId, HttpSession session)  
         继承于:SessionMappingStorage

ST示例:ST-23573-vwXU4ej0zAAYfmexmiyL-sso.cycore.cn(mappingId就是ST)

SessionId示例:kpyo6wtprbr01asqgu9d5cvgm

4、 进入时间:通过CAS服务器登录后,进入本应用系统的某个页面

 
 

 

5、单点登出(SingleSignOutFilter、SingleSignOutHttpSessionListener)
           a)功能:登出过滤器、监听器
           b) 先执行:SingleSignOutFilter-->doFilter()-->destroySession  SingleSignOutHandler-->destroySession()

1、执行HashMapBackedSessionMappingStorage-->removeBySessionById删除session
   MANAGED_SESSIONS.remove(key);
   ID_TO_SESSION_KEY_MAPPING.remove(sessionId);
2、执行session.invalidate()  【SingleSignOutHandler-->destroySession()】
c)再执行SingleSignOutHttpSessionListener-->sessionDestroyed()
   内部删除session方法
    MANAGED_SESSIONS.remove(key);
   ID_TO_SESSION_KEY_MAPPING.remove(sessionId);

     d) 根据b、c来看,监听器清除session的业务,在过滤器中已经执行过了,所有不用再次执行

 

 

Cas_个人理解的更多相关文章

  1. 理解CSS视觉格式化

    前面的话   CSS视觉格式化这个词可能比较陌生,但说起盒模型可能就恍然大悟了.实际上,盒模型只是CSS视觉格式化的一部分.视觉格式化分为块级和行内两种处理方式.理解视觉格式化,可以确定得到的效果是应 ...

  2. 彻底理解AC多模式匹配算法

    (本文尤其适合遍览网上的讲解而仍百思不得姐的同学) 一.原理 AC自动机首先将模式组记录为Trie字典树的形式,以节点表示不同状态,边上标以字母表中的字符,表示状态的转移.根节点状态记为0状态,表示起 ...

  3. 理解加密算法(三)——创建CA机构,签发证书并开始TLS通信

    接理解加密算法(一)--加密算法分类.理解加密算法(二)--TLS/SSL 1 不安全的TCP通信 普通的TCP通信数据是明文传输的,所以存在数据泄露和被篡改的风险,我们可以写一段测试代码试验一下. ...

  4. node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理

    一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...

  5. 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念

    一.前言     DDD(领域驱动设计)的一些介绍网上资料很多,这里就不继续描述了.自己使用领域驱动设计摸滚打爬也有2年多的时间,出于对知识的总结和分享,也是对自我理解的一个公开检验,介于博客园这个平 ...

  6. 学习AOP之透过Spring的Ioc理解Advisor

    花了几天时间来学习Spring,突然明白一个问题,就是看书不能让人理解Spring,一方面要结合使用场景,另一方面要阅读源代码,这种方式理解起来事半功倍.那看书有什么用呢?主要还是扩展视野,毕竟书是别 ...

  7. ThreadLocal简单理解

    在java开源项目的代码中看到一个类里ThreadLocal的属性: private static ThreadLocal<Boolean> clientMode = new Thread ...

  8. JS核心系列:理解 new 的运行机制

    和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中分配一个实例对象. 但在 javascript 中,万物皆对象,为什么还要通过 ...

  9. 深入理解JS 执行细节

    javascript从定义到执行,JS引擎在实现层做了很多初始化工作,因此在学习JS引擎工作机制之前,我们需要引入几个相关的概念:执行环境栈.全局对象.执行环境.变量对象.活动对象.作用域和作用域链等 ...

随机推荐

  1. USACO section1.2 Miking cows

    /* ID: vincent63 LANG: C TASK: milk2 */ #include <stdio.h> #include<stdlib.h> #include&l ...

  2. openfire+asmack搭建的安卓即时通讯(二) 15.4.9

    上期没有放成果图呢!忘了=-=,这就是上次的成果图,textview里面会显示登陆的名字(这个是默认管理员帐号=-=) 好吧,登陆了服务器我们就有了交互的功能啦可以说是前进了一大步呢!下面能我们就要试 ...

  3. poj-1083-Moving Tables(hdu-1050)

    Moving Tables Time Limit: 1000MS Memory Limit: 10000K Total Submissions: Accepted: Description The f ...

  4. ios开发之CoreData使用

    1.在工程中添加build Phases的Link Binary with Libraries下添加CoreData的库. 2.在当前工程中新建文件选择CoreData——>DataModel, ...

  5. CentOS7.2安装总结

    第一次自己写文章,想想还有点小激动呢.折腾了大半天,终于在一个没用的台式机上面装了个mini版的CentOS7.2.写这篇文章也是做个记载,要是以后再装要注意了. 一.安装过程 采用U盘安装.最初是准 ...

  6. POJ 1990 MooFest --树状数组

    题意:牛的听力为v,两头牛i,j之间交流,需要max(v[i],v[j])*dist(i,j)的音量.求所有两两头牛交谈时音量总和∑(max(v[i],v[j])*abs(x[j]-x[i])) ,x ...

  7. JavaWeb学习之Servlet(三)----Servlet的映射匹配问题、线程安全问题

    [声明] 欢迎转载,但请保留文章原始出处→_→ 文章来源:http://www.cnblogs.com/smyhvae/p/4140529.html 一.Servlet映射匹配问题: 在第一篇文章中的 ...

  8. SqlMapConfig.xml中的setting属性设置

    <settings     cacheModelsEnabled="true"     lazyLoadingEnabled="false"     en ...

  9. java9-2形式参数

    1.形式参数: 基本类型(太简单) 引用类型 类名:(匿名对象的时候其实我们已经讲过了)需要的是该类的对象 抽象类:需要的是该抽象的类子类对象 接口:需要的是该接口的实现类对象 A. 类名:(匿名对象 ...

  10. 工厂模式(Factory Patter)

    1.工厂模式简介 工厂模式属于创建型模式,是专门用来创建对象的模式,抽象了实例化的过程.工厂模式分为 : 工厂方法模式.抽象工厂模式. 在学习工厂方法模式.抽象工厂之前,首先先要了解一下简单工厂模式, ...