亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Spring Boot中使用LDAP來統一管理用戶信息的示例

2024-07-13 10:17:28
字體:
來源:轉載
供稿:網友

很多時候,我們在構建系統的時候都會自己創建用戶管理體系,這對于開發人員來說并不是什么難事,但是當我們需要維護多個不同系統并且相同用戶跨系統使用的情況下,如果每個系統維護自己的用戶信息,那么此時用戶信息的同步就會變的比較麻煩,對于用戶自身來說也會非常困擾,很容易出現不同系統密碼不一致啊等情況出現。如果此時我們引入LDAP來集中存儲用戶的基本信息并提供統一的讀寫接口和校驗機制,那么這樣的問題就比較容易解決了。下面就來說說當我們使用Spring Boot開發的時候,如何來訪問LDAP服務端。

LDAP簡介

LDAP(輕量級目錄訪問協議,Lightweight Directory Access Protocol)是實現提供被稱為目錄服務的信息服務。目錄服務是一種特殊的數據庫系統,其專門針對讀取,瀏覽和搜索操作進行了特定的優化。目錄一般用來包含描述性的,基于屬性的信息并支持精細復雜的過濾能力。目錄一般不支持通用數據庫針對大量更新操作操作需要的復雜的事務管理或回卷策略。而目錄服務的更新則一般都非常簡單。這種目錄可以存儲包括個人信息、web鏈結、jpeg圖像等各種信息。為了訪問存儲在目錄中的信息,就需要使用運行在TCP/IP 之上的訪問協議—LDAP。

LDAP目錄中的信息是是按照樹型結構組織,具體信息存儲在條目(entry)的數據結構中。條目相當于關系數據庫中表的記錄;條目是具有區別名DN (Distinguished Name)的屬性(Attribute),DN是用來引用條目的,DN相當于關系數據庫表中的關鍵字(Primary Key)。屬性由類型(Type)和一個或多個值(Values)組成,相當于關系數據庫中的字段(Field)由字段名和數據類型組成,只是為了方便檢索的需要,LDAP中的Type可以有多個Value,而不是關系數據庫中為降低數據的冗余性要求實現的各個域必須是不相關的。LDAP中條目的組織一般按照地理位置和組織關系進行組織,非常的直觀。LDAP把數據存放在文件中,為提高效率可以使用基于索引的文件數據庫,而不是關系數據庫。類型的一個例子就是mail,其值將是一個電子郵件地址。

LDAP的信息是以樹型結構存儲的,在樹根一般定義國家(c=CN)或域名(dc=com),在其下則往往定義一個或多個組織 (organization)(o=Acme)或組織單元(organizational units) (ou=People)。一個組織單元可能包含諸如所有雇員、大樓內的所有打印機等信息。此外,LDAP支持對條目能夠和必須支持哪些屬性進行控制,這是有一個特殊的稱為對象類別(objectClass)的屬性來實現的。該屬性的值決定了該條目必須遵循的一些規則,其規定了該條目能夠及至少應該包含哪些屬性。例如:inetorgPerson對象類需要支持sn(surname)和cn(common name)屬性,但也可以包含可選的如郵件,電話號碼等屬性。

LDAP簡稱對應

  1. o:organization(組織-公司)
  2. ou:organization unit(組織單元-部門)
  3. c:countryName(國家)
  4. dc:domainComponent(域名)
  5. sn:suer name(真實名稱)
  6. cn:common name(常用名稱)

入門示例

在了解了LDAP的基礎概念之后,我們通過一個簡單例子進一步理解!

創建一個基礎的Spring Boot項目(如果您還不會,可以參考這兩篇文章:入門1或入門2)

在pom.xml中引入兩個重要依賴

<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-data-ldap</artifactId></dependency><dependency>  <groupId>com.unboundid</groupId>  <artifactId>unboundid-ldapsdk</artifactId>  <scope>test</scope></dependency>

其中,spring-boot-starter-data-ldap是Spring Boot封裝的對LDAP自動化配置的實現,它是基于spring-data-ldap來對LDAP服務端進行具體操作的。

而unboundid-ldapsdk主要是為了在這里使用嵌入式的LDAP服務端來進行測試操作,所以scope設置為了test,實際應用中,我們通常會連接真實的、獨立部署的LDAP服務器,所以不需要此項依賴。

在src/test/resources目錄下創建ldap-server.ldif文件,用來存儲LDAP服務端的基礎數據,以備后面的程序訪問之用。

dn: dc=didispace,dc=comobjectClass: topobjectClass: domaindn: ou=people,dc=didispace,dc=comobjectclass: topobjectclass: organizationalUnitou: peopledn: uid=ben,ou=people,dc=didispace,dc=comobjectclass: topobjectclass: personobjectclass: organizationalPersonobjectclass: inetOrgPersoncn: didisn: zhaiyongchaouid: didiuserPassword: {SHA}nFCebWjxfaLbHHG1Qk5UU4trbvQ=

這里創建了一個基礎用戶,真實姓名為zhaiyongchao,常用名didi,在后面的程序中,我們會來讀取這些信息。更多內容解釋大家可以深入學習LDAP來理解,這里不做過多的講解。

在application.properties中添加嵌入式LDAP的配置

spring.ldap.embedded.ldif=ldap-server.ldifspring.ldap.embedded.base-dn=dc=didispace,dc=com

使用spring-data-ldap的基礎用法,定義LDAP中屬性與我們Java中定義實體的關系映射以及對應的Repository

@Data@Entry(base = "ou=people,dc=didispace,dc=com", objectClasses = "inetOrgPerson")public class Person {  @Id  private Name id;  @DnAttribute(value = "uid", index = 3)  private String uid;  @Attribute(name = "cn")  private String commonName;  @Attribute(name = "sn")  private String suerName;  private String userPassword;}public interface PersonRepository extends CrudRepository<Person, Name> {}

通過上面的定義之后,已經將Person對象與LDAP存儲內容實現了映射,我們只需要使用PersonRepository就可以輕松的對LDAP內容實現讀寫。

創建單元測試用例讀取所有用戶信息:

@RunWith(SpringRunner.class)@SpringBootTestpublic class ApplicationTests {  @Autowired  private PersonRepository personRepository;  @Test  public void findAll() throws Exception {    personRepository.findAll().forEach(p -> {      System.out.println(p);    });  }}

啟動該測試用例之后,我們可以看到控制臺中輸出了剛才維護在ldap-server.ldif中的用戶信息:

2018-01-27 14:25:06.283  WARN 73630 --- [           main] o.s.ldap.odm.core.impl.ObjectMetaData    : The Entry class Person should be declared final
Person(id=uid=ben,ou=people,dc=didispace,dc=com, uid=ben, commonName=didi, suerName=zhaiyongchao, userPassword=123,83,72,65,125,110,70,67,101,98,87,106,120,102,97,76,98,72,72,71,49,81,107,53,85,85,52,116,114,98,118,81,61)

添加用戶

通過上面的入門示例,如果您能夠獨立完成,那么在Spring Boot中操作LDAP的基礎目標已經完成了。

如果您足夠了解Spring Data,其實不難想到,這個在其下的子項目必然也遵守Repsitory的抽象。所以,我們可以使用上面定義的PersonRepository來輕松實現操作,比如下面的代碼就可以方便的往LDAP中添加用戶:

Person person = new Person();person.setUid("uid:1");person.setSuerName("AAA");person.setCommonName("aaa");person.setUserPassword("123456");personRepository.save(person);

如果還想實現更多操作,您可以參考spring-data-ldap的文檔來進行使用。

連接LDAP服務端

在本文的例子中都采用了嵌入式的LDAP服務器,事實上這種方式也僅限于我們本地測試開發使用,真實環境下LDAP服務端必然是獨立部署的。

在Spring Boot的封裝下,我們只需要配置下面這些參數就能將上面的例子連接到遠端的LDAP而不是嵌入式的LDAP。

spring.ldap.urls=ldap://localhost:1235spring.ldap.base=dc=didispace,dc=comspring.ldap.username=didispacespring.ldap.password=123456

本文代碼

可以通過下面兩個倉庫中查閱chapter3-2-10目錄:

Github:https://github.com/dyc87112/SpringBoot-Learning/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜精品福利在线观看| 亚洲小视频在线| 黄网站色欧美视频| 最近日韩中文字幕中文| 欧美日韩国产黄| 亚洲最新中文字幕| 国产精品久久久久免费a∨| 国产精品青青在线观看爽香蕉| 国产成人精品电影| 日本最新高清不卡中文字幕| 美女扒开尿口让男人操亚洲视频网站| 色狠狠久久aa北条麻妃| 日本91av在线播放| 日韩电影免费在线观看中文字幕| 日韩综合视频在线观看| 欧美亚洲另类激情另类| 国产精品视频免费在线观看| 国产精品入口尤物| 98午夜经典影视| 成人免费网站在线观看| 国产精品大陆在线观看| 亚洲18私人小影院| 国产精品久久久久久久久久东京| 欧美理论电影在线播放| 精品久久久一区二区| 欧美成人午夜激情| 亚洲欧洲激情在线| 午夜免费在线观看精品视频| 亚洲欧美另类在线观看| 日韩欧美999| 国产精品久久久久高潮| 欧美成人免费小视频| www.欧美精品一二三区| 亚洲国产精品电影在线观看| 国产亚洲欧美一区| 欧美三级xxx| 91精品国产91久久久久久不卡| 精品久久久一区| 欧美视频精品一区| 日韩激情视频在线播放| 国产精品美女久久久久av超清| 久久在精品线影院精品国产| 成人精品网站在线观看| 亚洲一区二区三区在线视频| 91欧美精品成人综合在线观看| 97在线日本国产| 欧美国产日韩一区| 国产日韩欧美视频在线| 2018中文字幕一区二区三区| 免费91在线视频| 欧美华人在线视频| 久久亚洲综合国产精品99麻豆精品福利| 欧美激情在线一区| 一区二区三区视频在线| 奇门遁甲1982国语版免费观看高清| 一区二区三区四区视频| 免费不卡欧美自拍视频| 日韩久久免费电影| 韩国v欧美v日本v亚洲| 26uuu另类亚洲欧美日本一| 51ⅴ精品国产91久久久久久| 日韩精品黄色网| 国语自产精品视频在线看抢先版图片| 菠萝蜜影院一区二区免费| 91精品国产乱码久久久久久蜜臀| 欧美理论电影网| 国产日韩欧美中文| 亚洲视频专区在线| 日韩高清不卡av| 国产v综合v亚洲欧美久久| 中文字幕亚洲综合久久| 一区二区三区黄色| 久久久久女教师免费一区| 日韩亚洲欧美中文在线| 日韩欧美在线免费观看| 亚洲欧美中文日韩在线v日本| 日韩一区二区av| 97视频在线免费观看| 97人人爽人人喊人人模波多| 欧美特黄级在线| 九九精品视频在线观看| 精品亚洲一区二区三区在线播放| 亚洲精品美女在线观看| 亚洲aaa激情| 亚洲色图av在线| 精品国产电影一区| 亚洲精品自产拍| 中文字幕日韩在线观看| 亚洲精品欧美极品| 在线观看亚洲视频| 超碰91人人草人人干| 97色在线视频| 亚洲毛片在线看| 国产丝袜精品视频| 一道本无吗dⅴd在线播放一区| 欧美精品在线网站| 怡红院精品视频| 日韩欧美在线网址| 久久人人爽人人爽爽久久| 国产精品女视频| 欧美激情视频一区二区三区不卡| 免费成人高清视频| 国产一区二区三区在线观看视频| 91精品久久久久久久| 欧美激情xxxxx| 日韩中文综合网| 久久深夜福利免费观看| 亚洲香蕉伊综合在人在线视看| 久久久久久中文字幕| 欧美日韩一二三四五区| 国产成人一区三区| 日韩经典中文字幕在线观看| 亚洲午夜av电影| 欧美日韩中文在线| 久久视频在线播放| 91av在线视频观看| 日韩精品一二三四区| 国产亚洲综合久久| 欧美午夜精品久久久久久久| 欧美激情亚洲另类| 亚洲精品国精品久久99热| 午夜精品久久久久久99热软件| 2018中文字幕一区二区三区| 国产a级全部精品| 欧美日产国产成人免费图片| 最新国产成人av网站网址麻豆| 欧美日韩一区二区在线播放| 91精品国产高清自在线| 91久久精品在线| 91精品在线看| 日韩精品极品在线观看播放免费视频| 国产噜噜噜噜噜久久久久久久久| 国产z一区二区三区| 国产自产女人91一区在线观看| 亚洲国产欧美久久| 91影视免费在线观看| 欧美高清无遮挡| 97香蕉超级碰碰久久免费软件| 精品国产乱码久久久久久天美| 亚洲欧美另类在线观看| 欧美做受高潮1| 日韩在线免费视频观看| 91视频九色网站| 精品爽片免费看久久| 欧美人与物videos| 欧美色欧美亚洲高清在线视频| 91网在线免费观看| 在线免费观看羞羞视频一区二区| 91色p视频在线| www.久久久久| 欧美伊久线香蕉线新在线| 久久精品99久久久久久久久| 97精品国产97久久久久久春色| 欧美最猛性xxxxx亚洲精品| 精品久久久一区| 国产欧美va欧美va香蕉在| 久久久天堂国产精品女人| 亚洲国产天堂久久国产91| 黑丝美女久久久| 国产婷婷97碰碰久久人人蜜臀| 日韩亚洲在线观看| 狠狠久久五月精品中文字幕| 亚洲视频在线观看视频| 国产精品丝袜高跟|