CAS-Server的配置

一、CAS 介绍(若只是搭建环境,可以忽略)

1.1 基础知识

TGT、ST是CAS1.0协议中就有的票据

TGT(Ticket Grangting Ticket)
关键点:
TGT封装了Cookie值(TGT对象的ID值就是cookie值(指的应当就是TGC吧))以及此Cookie值对应的用户信息。
CAS服务器中存储了 cookie(即TCG)----TGT, 拥有了TGT,用户就可以证明自己在CAS成功登录过。
认证服务认证通过(比如输入了正确的用户和口令后)后就能发放TGT

ST(Service Ticket服务票据)
关键点:
CAS服务器为用户签发的访问某一service的票据;
通过TGT签发一个ST
用户凭借ST去访问service,service拿ST去CAS服务器验证

把两者联系起来:
用户访问service时,service发现用户没有ST,则要求用户去CAS服务器获取ST。用户向CAS服务器发出获取ST的请求,如果用户的请求中包含cookie,则CAS服务器会以此cookie值为key查询缓存中有无TGT,如果存在TGT,则用此TGT签发一个ST,返回给用户。用户凭借ST去访问service,service拿ST去CAS服务器验证,验证通过后,允许用户访问资源。

TGC 安全性
1)对于一个 CAS 用户来说,最重要是要保护它的 TGC ,如果 TGC 不慎被 CAS Server 以外的实体获得, Hacker 能够找到该 TGC ,然后冒充 CAS 用户访问所有授权资源。
2)TGC 是 CAS Server 通过 SSL 方式发送给终端用户,因此,要截取 TGC 难度非常大,从而确保CAS 的安全性。但 CAS 的传输安全性仅仅依赖于 SSL 。
3)TGC 面临的风险 主要并非传输窃取,而是存活周期内( logout 前)被使用(如:离开了电脑)或窃取。

ST的安全性:
ST ( Service Ticket )是通过 Http 传送的,网络中的其他人可以 Sniffer 到其他人的 Ticket 。CAS 协议从几个方面让 Service Ticket 变得更加安全:
1) ST 是基于随机数生成的,且生成的一个ST只能使用一次: CAS协议规定,无论ST验证是否成功, CAS Server都会将服务端的缓存中的该Service Ticket清除 ,从而可以确保一个 Service Ticket 不被使用两次;
2) CAS 规定 Service Ticket 只能存活一定的时间,然后CAS Server会让它失效。可通过在web.xml中配置参数,让ST在多少秒内失效。

1.2 用户访问流程流程实例

用户第一次访问一个CAS 服务的客户web 应用时(例如访问URL :http://192.168.1.90:8081/web1 ),部署在客户web 应用的cas AuthenticationFilter ,会截获此请求,生成service 参数,然后redirect 到CAS 服务的login 接口,url为https://cas:8443/cas/login?service=http%3A%2F%2F192.168.1.90%3A8081%2Fweb1%2F ,认证成功后,CAS 服务器会生成认证cookie ,写入浏览器,同时将cookie 缓存到服务器本地,CAS 服务器还会根据service 参数生成ticket,ticket 会保存到服务器,也会加在url 后面,然后将请求redirect 回客户web 应用,url 为http://192.168.1.90:8081/web1/?ticket=ST-5-Sx6eyvj7cPPCfn0pMZuMwnbMvxpCBcNAIi6-20

这时客户端的AuthenticationFilter 看到ticket 参数后,会跳过,由其后面的TicketValidationFilter 处理,TicketValidationFilter 会利用httpclient 工具访问cas 服务的/serviceValidate 接口, 将ticket 、service 都传到此接口,由此接口验证ticket 的有效性,TicketValidationFilter 如果得到验证成功的消息,就会把用户信息写入web 应用的session里。

至此为止,SSO 会话就建立起来了,以后用户在同一浏览器里访问此web 应用时,AuthenticationFilter 会在session 里读取到用户信息,所以就不会去CAS 认证,如果在此浏览器里访问别的web 应用时,AuthenticationFilter 在session 里读取不到用户信息,会去CAS 的login 接口认证,但这时CAS 会读取到浏览器传来的cookie ,所以CAS 不会要求用户去登录页面登录,只是会根据service 参数生成一个ticket ,然后再和web 应用做一个验证ticket 的交互。

二、交互认证实战

前置动作:

第一、生成证书

数字证书是指在互联网通讯中标志通讯各方身份信息的一个数字认证,人们可以在网上用它来识别对方的身份

Keytool 是一个Java 数据证书的管理工具 ,Keytool 将密钥和证书存在一个称为keystore的文件中.
在keystore里,包含两种数据:
1、密钥实体——密钥又或者是私钥和配对公钥(采用非对称加密)
2、可信任的证书实体——只包含公钥

keytool -genkey -alias ssodemo -keyalg RSA -keysize 1024 -keypass yinbodotcc -validity 365 -keystore D:\yinbodotcc.keystore -storepass yinbodotcc

keytool -export -alias ssodemo -keystore d:\yinbodotcc.keystore -file d:\ssodemo.crt -storepass yinbodotcc

客户端导入证书(我们这里客户端和服务端都在同一台机器上):

keytool -import -keystore %JAVA_HOME%\jre\lib\security\cacerts -file d:\ssodemo.crt -alias ssodemo
image.png

image.png

image.png
第二、配置本地DNS
image.png

这里server.yinbodotcc. com和keygen命令中“名字与姓氏”后面输入的要一样才行

第三、CAS-Server环境部署

1、 部署CAS-Server相关的Tomcat
解压apache-tomcat-7.0.100-windows-x64.zip,修改apache-tomcat-7.0.100\conf\server.xml文件

<Connector port="8443" protocol="org.apache.coyote.http11.Http11Protocol" maxThreads="150" SSLEnabled="true" scheme="https" secure="true"     keystoreFile="d:\yinbodotcc.keystore" keystorePass="yinbodotcc" clientAuth="false" sslProtocol="TLS" />
image.png

image.png

2、部署CAS-Server
http://www.jasig.org/cas/download 下载 cas-server-4.0.0-release.zip,
取cas-server-4.0.0-release\cas-server-4.0.0\modules\cas-server-webapp-4.0.0.war 放到 apache-tomcat-7.0.100\webapps\下, 然后启动浏览器(war会被自动被解压并动态加载):

image.png

2.1 使用MySQL存储用户认证口令

1、需要的几个jar包:

把c3p0-0.9.1.2.jar、cas-server-support-jdbc-4.0.0.jar和mysql-connector-java-5.1.13-bin.jar放到E:\apache-tomcat-7.0.57\webapps\cas\WEB-INF\lib目录下:


image.png

2、修改配置,支持mysql数据库交互验证

配置文件:deployerConfigContext.xml
image.png

image.png

为便于copy,配置文件关键部分摘录如下:

<entry key-ref="proxyAuthenticationHandler" value-ref="proxyPrincipalResolver" />
                <!--entry key-ref="primaryAuthenticationHandler" value-ref="primaryPrincipalResolver" /-->
                <!-- key-ref指定自己的本地数据库访问 -->
                <entry key-ref="dbAuthHandler" value-ref="primaryPrincipalResolver"/>





<!-- 指定c3p0数据源 -->  
    
    <bean id="dataSource"
      class="com.mchange.v2.c3p0.ComboPooledDataSource"
     p:driverClass="com.mysql.jdbc.Driver"
     p:jdbcUrl="jdbc:mysql://localhost:3306/mysql?useUnicode=true&amp;characterEncoding=UTF-8&amp;zeroDateTimeBehavior=convertToNull"
      p:user="root"
      p:password="Java19790206" 
      />      
        
    <!-- 访问本地数据库 -->
    <bean id="dbAuthHandler"
          class="org.jasig.cas.adaptors.jdbc.QueryDatabaseAuthenticationHandler"
          p:dataSource-ref="dataSource"
          p:sql="SELECT u.`password` FROM `test_sec_user` u WHERE u.`account` = ?" />

image.png

登录演示效果如下:


image.png

image.png

2.2 使用LDAP(openLDAP)里面存储的用户和口令

2.3 使用Redis里面存储的用户和口令

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,277评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,689评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,624评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,356评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,402评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,292评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,135评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,992评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,429评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,636评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,785评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,492评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,092评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,723评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,858评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,891评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,713评论 2 354

推荐阅读更多精彩内容