单点登陆CAS使用Mysql数据库中用户和密码进行验证

1.首先准备两台服务器进行测试

服务器IP功能
Tomcat CAS Server192.168.73.146运行Tomcat和CAS服务器
Mysql Server192.168.73.147运行Mysql数据库

2.启动Mysql数据
在这里插入图片描述
3.创建数据库以及数据表

创建数据库以及数据表

DROP DATABASE IF EXISTS shirodb ;
CREATE DATABASE shirodb CHARACTER SET UTF-8 ;
USE shirodb ;
CREATE TABLE member (
   mid VARCHAR(50),
   password VARCHAR(50),
   name INT,
   locaked INT ,
   CONSTRAINT pk_mid PRIMARY KEY (mid)
) ENGINE = INNODB ;

添加数据

USE shirodb ;
INSERT INTO member (mid,password,name,locked) VALUES ('admin','hello','管理员',0);
INSERT INTO member (mid,password,name,locked) VALUES ('mermaid','hello','老盛',0);
INSERT INTO member (mid,password,name,locked) VALUES ('sheng','hello','小伟',0);

4.cas服务器连接mysql
(1)准备jar包

序号jar包
1c3p0-0.9.5.2.jar
2mchange-commons-java-0.2.11.jar
3cas-server-support-jdbc-4.1.5.jar
4mysql-connector-java-5.0.8-bin.jar

将如上jar下载在tomcat目录中cas的WEB-INF的lib目录下
在这里插入图片描述

5.修改cas服务器的配置文件

配置文件 deployerConfigContext.xml 位置如下
在这里插入图片描述
配置数据源,加入以下内容


<bean id="dateSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!--${}是引入properties文件内容的-->
        <property name="driverClass" value="org.gjt.mm.mysql.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://192.168.73.146:3306/shirodb"/>
        <property name="user" value="root"/>
        <property name="password" value="123"/>
        <property name="maxPoolSize" value="1"/>
        <property name="minPoolSize" value="1"/>
        <property name="initialPoolSize" value="1"/>
        <property name="maxIdleTime" value="20"/>
    </bean>

增加数据检测验证器,加入如下内容

<bean id="dbAuthHandler" class="org.jasig.cas.adaptors.jdbc.QueryDatabaseAuthenticationHandler">
	    <property name="dateSource" ref="dataSource"/>
		<property name="sql" value="select password from member where mid=? AND locked=0"/>
</bean>

修改权限处理类,下面需要做一个配置项的替换将

<entry key-ref="primaryPrincipalResolver" value-ref="primaryPrincipalResolver" />

替换为

<entry key-ref="dbAuthHandler" value-ref="primaryPrincipalResolver" />

6.启动tomcat

如果启动有问题可以进入tomcat中的logs目录中查询
在这里插入图片描述
登陆入服务器地址
在这里插入图片描述
出现CAS验证窗口,输入数据库保存的用户名和密码
在这里插入图片描述
成功!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值