zoukankan      html  css  js  c++  java
  • Cas 服务器 JDBC身份校验

    之前的Cas服务器一直使用静态配置的账号密码进行身份认证,现在要让Cas服务器通过MySQL数据库中的用户信息进行身份认证。

    一、添加数据库访问依赖

     <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->

    <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.12</version>
    </dependency>
    <!--jdbc认证需要添加cas的依赖包,其他数据源请按类型更换-->
    <dependency>
    <groupId>org.apereo.cas</groupId>
    <artifactId>cas-server-support-jdbc</artifactId>
    <version>${cas.version}</version>
    </dependency>

    二、创建数据库表并添加数据

    注:数据采用最简、密码明文,要进行加密的话也很简单,文章中不做说明。

    三、配置Cas服务器进行数据查询

    # 查询账号密码sql,必须包含密码字段
    cas.authn.jdbc.query[0].sql=select * from user where userName=?
    cas.authn.jdbc.query[0].fieldPassword=password
    #cas.authn.jdbc.query[0].fieldExpired=expired 无过期
    #cas.authn.jdbc.query[0].fieldDisabled=disabled 无禁用
    cas.authn.jdbc.query[0].dialect=org.hibernate.dialect.MySQLDialect
    cas.authn.jdbc.query[0].driverClass=com.mysql.jdbc.Driver
    cas.authn.jdbc.query[0].url=jdbc:mysql://127.0.0.1:3306/shriodb?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
    cas.authn.jdbc.query[0].user=root
    cas.authn.jdbc.query[0].password=123456

    #加密策略,默认NONE不加密
    cas.authn.jdbc.query[0].passwordEncoder.type=NONE

    四、运行测试

  • 相关阅读:
    通过实验窥探javascript的解析执行顺序
    HTML5实战与剖析之原生拖拽(四可拖动dragable属性和其他成员)
    Google Guava之Optional优雅的使用null
    sharding-jdbc源码学习(一)简介
    重构——改善既有代码的设计
    spring自定义标签
    java自定义注解
    开源项目集合
    Lombok引入简化Java代码
    设计模式之建造者模式
  • 原文地址:https://www.cnblogs.com/dw039/p/9869795.html
Copyright © 2011-2022 走看看