CAS实现SSO 学习(四)

原创 2015年07月09日 14:57:19

(四):实现基于数据库的身份验证

1.下载 Microsoft JDBC Driver for SQL Server。

(1)Microsoft JDBC Driver 4.0 for SQL Server 下载地址:http://www.microsoft.com/zh-cn/download/details.aspx?id=11774

网站提供了两种格式文件供下载,一种是自解压的EXE格式文件,还有一种是tar.gz格式的压缩文件。两种格式选其一下载即可,经过解压缩,可以得到两个JAR格式文件:sqljdbc.jar与sqljdbc4.jar。

(2)由于本人使用的是SQL Server 2012,因此需将“sqljdbc4.jar”拷贝至“%TOMCAT_HOME%\webapps\cas\WEB-INF\lib”文件夹。

(3)在本系列第二部分曾经提及从CAS网站下载“cas-server-3.5.1-release.zip”并解压缩。在解压缩的文件下中找到“modules\cas-server-support-jdbc-3.5.1.jar”,将其一并拷贝至“%TOMCAT_HOME%\webapps\cas\WEB-INF\lib”文件夹。

 

2.创建用于身份验证的数据库

(1)启动SQL Server Management Studio,新建一数据库“UsersDB”,并在其中建立表“Users”,字段如下:

(2)在表中输入若干测试数据.

3.配置CAS实现基于数据库的身份验证

(1)以管理员身份启动文本编辑工具,打开“%TOMCAT_HOME%\webapps\cas\WEB-INF\deployerConfigContext.xml”。找到下面的代码

<span style="font-family:Microsoft YaHei;"><bean id="authenticationManager"
    class="org.jasig.cas.authentication.AuthenticationManagerImpl">
</span>

(2)在该段代码前面插入 SQL Server JDBC 数据源配置信息:

<span style="font-family:Microsoft YaHei;">
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"></property>
    <property name="url" value="jdbc:sqlserver://yoursqlurl;databaseName=UsersDB"></property>
    <property name="username" value="sa"></property>
    <property name="password" value="YourPassword"></property>
</bean>
</span>
如下图所示:

(3)找到如下配置信息:

<span style="font-family:Microsoft YaHei;">
<bean class="org.jasig.cas.authentication.handler.support.SimpleTestUsernamePasswordAuthenticationHandler" />

</span>

该配置信息使用SimpleTestUsernamePasswordAuthenticationHandler验证用户,即默认用户名和密码相同则验证通过,用户名密码不同则登录失败。我们需要将其替换成基于数据库验证的配置信息。

首先将上面的配置信息注释掉,并在其下面插入如下配置信息:

<span style="font-family:Microsoft YaHei;">
<bean class="org.jasig.cas.adaptors.jdbc.QueryDatabaseAuthenticationHandler">
    <property name="sql" value="select Password from users where username=?" />
    <property name="dataSource" ref="dataSource" />
</bean>

</span>
说明:如果你安装的是SQL Server 2012,那么默认TCP/IP访问协议不会打开,因此无法通过IP地址的方式访问SQL Server数据,解决办法就是启动SQL Server配置管理器,并在里面启用TCP/IP,启用后记得重新启动SQL Server服务以使设置生效。如图所示:



(4)保存对“%TOMCAT_HOME%\webapps\cas\WEB-INF\deployerConfigContext.xml”所做的修改。

(5)重新启动 Tomcat 服务。

4.测试基于数据库的身份验证

从客户端运行前面调试好的WebForm程序,输入库中配置的用户名及密码,测试是否登录成功。如果一切配置正常,可以看到程序登录后的界面如下图:

参考:http://www.cnblogs.com/zhenyulu/archive/2013/01/26/2878271.html

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

CAS实现SSO 学习(一)

服务器 客户机 IP 地址 10.58.8.219 10.58.8.219 操作系统 Windows 7 x64 Windows 7 x64 软件 JDK 7A...
  • T_6666
  • T_6666
  • 2015年06月25日 16:15
  • 363

SSO单点登录学习总结(3)—— 基于CAS实现单点登录实例

第一:        本demo在一个机器上实现(三个虚拟主机),来看SSO单点登录实例(我们可以布到多个机器上使用都是同一个道理的),一个服务器主机,和两个客户端虚拟主机 ...

CAS实现SSO 学习(三)

1. 下载.NET CAS client。 .NET CAS Client 下载地址:https://wiki.jasig.org/display/CASC/.Net+Cas+Client 下载“do...
  • T_6666
  • T_6666
  • 2015年07月08日 16:34
  • 393

CAS实现SSO 学习(五)

(五)扩展基于数据库的身份验证 1. 应用场景 前面提到的基于数据库的集中身份验证主要是通过用户名、密码的方式完成验证操作,然而在实际使用过程中,用户可能需要多种形式的认证手段,除了用户名密码...
  • T_6666
  • T_6666
  • 2015年07月09日 15:24
  • 227

架构师熟悉cas技术方案实现sso

  • 2017年07月30日 10:22
  • 344KB
  • 下载

用YALE -CAS实现SSO

  • 2008年09月17日 16:47
  • 149KB
  • 下载

CAS实现SSO单点登录原理

1.      CAS简介 1.1.  What is CAS? CAS(Central Authentication Service) 是 Yale大学发起的一个企业级的、开源的项目,旨在为 W...
  • canlets
  • canlets
  • 2016年03月30日 13:24
  • 5085

cas sso学习心得

  • 2012年11月08日 15:30
  • 34KB
  • 下载

cas配置实现sso登录

  • 2014年11月06日 00:18
  • 11.89MB
  • 下载

CAS实现单点登录SSO执行原理探究(终于明白了)

一、不落俗套的开始1、背景介绍单点登录:Single Sign On,简称SSO,SSO使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。CAS框架:CAS(Central A...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:CAS实现SSO 学习(四)
举报原因:
原因补充:

(最多只允许输入30个字)