Spring Security 学习之LDAP认证

简介:

一、前言

LDAP:轻型目录访问协议,即Lightweight Directory Access Protocol (LDAP)是一个访问在线目录服务的协议,最典型例子的就是黄页、电话簿等,主要用于读极多并且写极少的场景。


LDAP服务器:


二、Spring配置

  1. ldap-server:


    目标LDAP配置,即协议、IP、端口、用户名、密码等,如:

    1
    < security:ldap-server  url = "ldap://localhost:10389/o=apple"  manager-dn = "uid=admin,ou=system"  manager-password = "secret"  />


    Spring支持内嵌的LDAP测试服务器配置,ADS有提供相关的jar,内嵌LDAP服务器只需要指定root和ldif文件即可,不需要协议IP端口等配置,ldif文件可以使用ADS开发工具编辑,如:

    1
    < security:ldap-server  root = "o=apple"  ldif = "classpath:apple.ldif" />


  2. ldap-authentication-provider:

    用户认证授权相关配置,主要是用户配置用户组合用户过滤规则,方便快速从LDAP服务器定位到用户信息,如:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    < security:authentication-manager >
                 < security:ldap-authentication-provider 
                         user-search-filter = "(uid={0})"
                         user-search-base = "ou=users"
                         group-search-filter = "(uniqueMember={0})"
                         group-search-base = "ou=groups"
                         group-role-attribute = "cn"
                         role-prefix = "ROLE_" >
                 </ security:ldap-authentication-provider >
         </ security:authentication-manager >

    wKioL1MK57KiW7jkAADS-65MRbs628.jpg


user-dn-pattern: 用户dn过滤规则,如user-dn-pattern="uid={0},ou=people", uid={0}表示过滤uid属性

user-search-base: 指定从哪个分支开始查找用户,如user-search-base="ou=people",默认从root开始

user-search-filter: 用户过滤规则,如user-search-filter="(uid={0})" ,与user-dn-pattern类似,使用一个即可

group-search-base: 指定从哪个分支开始查找用户用户组,如group-search-base="ou=groups"

group-search-filter: 用户组过滤规则,如group-search-filter="(uniqueMember={0})"表示使用uniqueMember属性过滤

group-role-attribute: 用户组中Role映射属性,默认为cn,验证时会自动增加role前缀

role-prefix : role前缀, 默认为"ROLE_",即role-prefix="ROLE_"


通过以上基本的配置即可支持LDAP认证授权。


三、高级配置

Spring强大的功能之一就是在提供简便配置的同时支持自己定制,而定制最基础的就是bean配置,通过替换bean的实现可以替换掉spring原先提供的默认实现。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
< bean  id = "contextSource"
         class = "org.springframework.security.ldap.DefaultSpringSecurityContextSource" >
   < constructor-arg  value = "ldap://monkeymachine:389/dc=springframework,dc=org" />
   < property  name = "userDn"  value = "cn=manager,dc=springframework,dc=org" />
   < property  name = "password"  value = "password" />
</ bean >
< bean  id = "ldapAuthProvider"
     class = "org.springframework.security.ldap.authentication.LdapAuthenticationProvider" >
  < constructor-arg >
    < bean  class = "org.springframework.security.ldap.authentication.BindAuthenticator" >
      < constructor-arg  ref = "contextSource" />
      < property  name = "userDnPatterns" >
        < list >< value >uid={0},ou=people</ value ></ list >
      </ property >
    </ bean >
  </ constructor-arg >
  < constructor-arg >
    < bean
      class = "org.springframework.security.ldap.userdetails.DefaultLdapAuthoritiesPopulator" >
      < constructor-arg  ref = "contextSource" />
      < constructor-arg  value = "ou=groups" />
      < property  name = "groupRoleAttribute"  value = "ou" />
    </ bean >
  </ constructor-arg >
</ bean >
< bean  id = "userSearch"
     class = "org.springframework.security.ldap.search.FilterBasedLdapUserSearch" >
   < constructor-arg  index = "0"  value = "" />
   < constructor-arg  index = "1"  value = "(uid={0})" />
   < constructor-arg  index = "2"  ref = "contextSource"  />
</ bean >


Spring已经提供对LDAP认证的强大支持,一般情况下不需要自己定制。




     本文转自sarchitect 51CTO博客,原文链接:http://blog.51cto.com/stevex/1362706,如需转载请自行联系原作者




相关文章
|
1月前
|
JSON 安全 Java
什么是JWT?如何使用Spring Boot Security实现它?
什么是JWT?如何使用Spring Boot Security实现它?
200 5
|
3月前
|
安全 Java 数据库
安全无忧!在 Spring Boot 3.3 中轻松实现 TOTP 双因素认证
【10月更文挑战第8天】在现代应用程序开发中,安全性是一个不可忽视的重要环节。随着技术的发展,双因素认证(2FA)已经成为增强应用安全性的重要手段之一。本文将详细介绍如何在 Spring Boot 3.3 中实现基于时间的一次性密码(TOTP)双因素认证,让你的应用安全无忧。
171 5
|
27天前
|
安全 Java 数据安全/隐私保护
基于内存认证的 Spring Security
通过本文的介绍,希望您能够深入理解基于内存认证的Spring Security配置与使用方法,并能够在实际开发中灵活应用这一技术,提升应用的安全性和用户体验。
51 9
|
2月前
|
JSON 安全 算法
Spring Boot 应用如何实现 JWT 认证?
Spring Boot 应用如何实现 JWT 认证?
83 8
|
2月前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
73 9
|
3月前
|
前端开发 Java 数据库
SpringBoot学习
【10月更文挑战第7天】Spring学习
46 9
|
2月前
|
Java Kotlin 索引
学习Spring框架特性及jiar包下载
Spring 5作为最新版本,更新了JDK基线至8,修订了核心框架,增强了反射和接口功能,支持响应式编程及Kotlin语言,引入了函数式Web框架,并提升了测试功能。Spring框架可在其官网下载,包括文档、jar包和XML Schema文档,适用于Java SE和Java EE项目。
36 0
|
3月前
|
XML Java 数据格式
Spring学习
【10月更文挑战第6天】Spring学习
30 1
|
3月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
120 2
|
3月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
318 1

热门文章

最新文章