分为三个部分
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. Linux 系统常用命令汇总(七) 安全设置

     安全设置 分类 命令 选项 注解 安全策略 selinux setenforce number(0,1) 设置selinux状态,0关闭,1开启 getenforce 显示当前selinux状态,e ...

  2. 多次访问节点的DFS POJ 3411 Paid Roads

    POJ 3411 Paid Roads Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6553   Accepted: 24 ...

  3. 矩阵乘法快速幂 codevs 1732 Fibonacci数列 2

    1732 Fibonacci数列 2  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 在“ ...

  4. 1.素数判定(如何输出\n,\t,不用关键字冲突)

    题目描述 Description 质数又称素数.指在一个大于1的自然数中,除了1和此整数自身外,不能被其他自然数整除的数. 素数在数论中有着很重要的地位.比1大但不是素数的数称为合数.1和0既非素数也 ...

  5. Dvwa writeup

    DVWA(Dam vulnerable Web Application)是使用PHP+Mysql编写的一套用于常规漏洞教学和漏洞挖掘的一个测试学习程序,在此程序中包含了常见的web方面的漏洞,如命令行 ...

  6. Linux系统批量化安装部署之Cobbler

    说明: Cobbler服务器系统:CentOS 5.10 64位 IP地址:192.168.21.128 需要安装部署的Linux系统: eth0(第一块网卡,用于外网)IP地址段:192.168.2 ...

  7. iOS9新特性——堆叠视图UIStackView

    一.引言 随着autolayout的推广开来,更多的app开始使用自动布局的方式来构建自己的UI系统,autolayout配合storyBoard和一些第三方的框架,对于创建约束来说,已经十分方便,但 ...

  8. POJ 3461 Oulipo

      E - Oulipo Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit ...

  9. C# winform版 nbtstat

    参考:http://www.cnblogs.com/geqinggao/archive/2013/01/21/2869644.html 一.nbtstat命令 显示基于 TCP/IP 的 NetBIO ...

  10. linux添加时间提示符

    给PS1添加\t [root@lanny ~]# echo $PS1 [\u@\h \W]\$ [root@lanny ~]# export PS1="[\u@\h \W\t]\$" ...