国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Java > 正文

Spring Boot 連接LDAP的方法

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

本文是Spring Boot系列文集中關于LDAP連接相關操作的一文。僅僅涉及基本的使用ODM來快速實現LDAP增刪改查操作。詳細的關于Spring LDAP的其他操作,可以參考翻譯的官方文檔。

本文目的:使用Spring Boot構建項目,幫助讀者快速配置并使用Spring LDAP操作LDAP。大致步驟如下:

1.創(chuàng)建Spring Boot項目(約1分鐘)

 2.添加pom.xml文件中Spring LDAP依賴(約1分鐘)

3.配置Spring LDAP連接信息(約1分鐘)

4.創(chuàng)建實體類作為LDAP中的entry映射(ODM映射功能,類似ORM)

5.使用ldapTemplate書寫service層的方法(約3分鐘)

6.編寫controller層(約3分鐘)

1.創(chuàng)建Spring Boot項目(約1分鐘)

IDEA中點擊file - new - project

Spring,Boot,連接LDAP,LDAP

圖1

如上圖,選擇左側的 Spring Initializr幫助初始化spring項目,配置好SDK后,點擊next。

Spring,Boot,連接LDAP,LDAP

圖2

點擊后,如圖2,如果只是做demo,該頁面默認即可,點擊next。

Spring,Boot,連接LDAP,LDAP

圖3

如圖3,我們選擇web,右側會顯示web相關的組件,我們選擇右側中的Web,將其前面的框勾選上。這代表在創(chuàng)建的spring boot項目中會引入web相關的依賴。點擊next。

Spring,Boot,連接LDAP,LDAP

圖4

如圖4,這里自己命名即可,點擊finish。

2.添加pom.xml文件中Spring LDAP依賴(約1分鐘)

Spring,Boot,連接LDAP,LDAP

圖5

如上圖圖5,在項目中雙擊pom.xml來添加依賴。

Spring,Boot,連接LDAP,LDAP

圖6

如圖6所示,文件中已經加載了spring-boot-starter-web依賴,我們要使用Spring LDAP來操作LDAP服務器需要添加spring-boot-starter-data-ldap。該依賴會自動加載spring-ldap-core 與 spring-data-ldap依賴。其中spring-ldap-core是ldap操作的核心依賴,而spring-data-ldap提供了ODM的功能,能夠簡化操作。我們可以在項目的External Libraries中看到這兩個依賴,如下圖圖7中三個黃色高亮處:

Spring,Boot,連接LDAP,LDAP

圖7

3.配置Spring LDAP連接信息

Spring,Boot,連接LDAP,LDAP

圖8

如上圖圖8,根據spring boot官網對ldap配置的說明來配置,可以看這里。這樣配置之后,spring boot會自動讀取該配置。

4.創(chuàng)建實體類作為LDAP中的entry映射

本例中使用ODM功能,極大的簡化了LDAP的操作,關于ODM更多的信息,可以參考翻譯的官方文檔。

我們在項目中創(chuàng)建如下結構:

Spring,Boot,連接LDAP,LDAP

圖9

現在,我們在entry包下寫與entry互相映射的實體類。其中,我的LDAP結構如下

Spring,Boot,連接LDAP,LDAP

圖10

新建Person類

package com.example.demo.entry;import com.fasterxml.jackson.annotation.JsonIgnore;import org.springframework.ldap.odm.annotations.Attribute;import org.springframework.ldap.odm.annotations.Entry;import org.springframework.ldap.odm.annotations.Id;import org.springframework.ldap.support.LdapNameBuilder;import javax.naming.Name;/** * @Author: geng_pool * @Description: * @Date: Created in 2017/12/27 10:24 * @Modified by: */@Entry(objectClasses = {"organizationalPerson","person","top"},base = "o=myorg")public class Person { @Id @JsonIgnore private Name dn; @Attribute(name="cn") private String cn; @Attribute(name="sn") private String sn; @Attribute(name="userPassword") private String userPassword; public Person(String cn) {  Name dn = LdapNameBuilder.newInstance()    .add("o", "myorg")    .add("cn", cn)    .build();  this.dn = dn; } public Person(){} /* getter */ public Name getDn() {  return dn; } public String getCn() {  return cn; } public String getSn() {  return sn; } public String getUserPassword() {  return userPassword; } /* setter */ public void setDn(Name dn) {  this.dn = dn; } public void setCn(String cn) {  this.cn = cn;  if(this.dn==null){   Name dn = LdapNameBuilder.newInstance()     .add("o", "myorg")     .add("cn", cn)     .build();   this.dn = dn;  } } public void setSn(String sn) {  this.sn = sn; } public void setUserPassword(String userPassword) {  this.userPassword = userPassword; } @Override public String toString() {  return "Person{" +    "dn=" + dn.toString() +    ", cn='" + cn + '/'' +    ", sn='" + sn + '/'' +    ", userPassword='" + userPassword + '/'' +    '}'; }}

注意@Entry與@Id為必須的。而@JsonIgnore是為了將person傳給前端時不報錯,因為Name類型的無法自動解析成json格式。注意我為了方便,在 public Person(String cn) {}構造方法中寫上了DN值的生成方法,在setCn中也寫上了該方法,當然存在代碼重復問題,忽略就好。

5.使用ldapTemplate書寫service層的方法

在service包中,新建OdmPersonRepo類

package com.example.demo.service;import com.example.demo.entry.Person;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.ldap.core.LdapTemplate;import org.springframework.stereotype.Service;import static org.springframework.ldap.query.LdapQueryBuilder.query;/** * @Author: geng_pool * @Description: * @Date: Created in 2017/12/27 10:37 * @Modified by: */@Servicepublic class OdmPersonRepo { @Autowired private LdapTemplate ldapTemplate; public Person create(Person person){  ldapTemplate.create(person);  return person; } public Person findByCn(String cn){  return ldapTemplate.findOne(query().where("cn").is(cn),Person.class); } public Person modifyPerson(Person person){  ldapTemplate.update(person);  return person; } public void deletePerson(Person person){  ldapTemplate.delete(person); }}

可以看到,基本的增刪改查操作都幫我們實現了,我們只要調用一下ldapTemplate中的方法即可。若要更自由的操作ldap的增刪改查,可參閱翻譯的官方文檔。

6.編寫controller層

在controller包下,新建一個testController類來測試LDAP的操作。

package com.example.demo.controller;import com.example.demo.entry.Person;import com.example.demo.service.OdmPersonRepo;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.ldap.core.LdapTemplate;import org.springframework.web.bind.annotation.*;/** * @Author: geng_pool * @Description: * @Date: Created in 2017/12/27 10:50 * @Modified by: */@RestControllerpublic class testController { @Autowired private OdmPersonRepo odmPersonRepo;  @RequestMapping(value = "/findOne",method = RequestMethod.POST) public Person findByCn(@RequestParam(name = "cn",required = true) String cn){  return odmPersonRepo.findByCn(cn); } @PostMapping(value = "/create") public Person create(@RequestParam(name = "cn") String cn,@RequestParam(name = "sn") String sn,@RequestParam(name = "userPassword") String userPassworld){  Person person = new Person();  person.setCn(cn);  person.setSn(sn);  person.setUserPassword(userPassworld);  return odmPersonRepo.create(person); } @PostMapping(value = "/update") public Person update(@RequestParam(name = "cn") String cn,@RequestParam(name = "sn") String sn,@RequestParam(name = "userPassword") String userPassworld){  Person person = new Person();  person.setCn(cn);  person.setSn(sn);  person.setUserPassword(userPassworld);  return odmPersonRepo.modifyPerson(person); } @PostMapping(value = "/delete") public void delete(@RequestParam(name = "cn")String cn){  Person person = new Person();  person.setCn(cn);  odmPersonRepo.deletePerson(person); }}

至此,一個基本的demo完成啦。下面我們測試一下

測試

為了大家都能跟著步驟來,我就不使用Postman來測試,而是在瀏覽器中測試接口。、

啟動spring boot,沒有報錯的話,打開瀏覽器到 localhost:8080/ ,按下F12,彈出開發(fā)者模式,找到console控制臺方便我們發(fā)送測試語句。

首先,引入jquery.js。打開jquery.js,全選-復制-在console中粘貼-回車,如下圖:

Spring,Boot,連接LDAP,LDAP

圖11

顯示為true,代表加載成功,我們可以使用jquery的ajax來測試了。

新增數據

Spring,Boot,連接LDAP,LDAP

圖12

正如controller層的testController要求的那樣,我們在地址 /create 上使用post方法,將數據cn sn userPassword傳過去

Spring,Boot,連接LDAP,LDAP

圖13

而在LDAP服務器中,也顯示了新增的數據

Spring,Boot,連接LDAP,LDAP

圖14

查找數據

Spring,Boot,連接LDAP,LDAP

圖15

也能根據cn正確查找到數據。

修改數據

Spring,Boot,連接LDAP,LDAP

圖16

我們查看LDAP中是否修改

Spring,Boot,連接LDAP,LDAP

圖17

可以看到能夠正常修改數據

刪除數據

 Spring,Boot,連接LDAP,LDAP

圖18

查看LDAP中是否刪除

Spring,Boot,連接LDAP,LDAP

圖19

可以看到,數據被正確刪除了。

其他說明

  1. 剛才的例子中,代碼有需要完善的地方,但對于demo演示來說完全可以忍受。大家可能也看到了這么做也有些缺點,我在update的時候,需要將修改后的person的所有屬性值都傳到后臺來(這也不算啥缺點,關系數據庫的更新也是這樣),并且不能修改cn的值(這就是為什么其他例子中都是使用uid來作為dn的一部分,類似于關系數據庫的主鍵的作用),因為修改后該entry的dn值就變化了,ODM就無法確定更新哪個數據。會報 javax.naming.NameNotFoundException: [LDAP: error code 32 - No Such Object] 錯誤。
  2. 刪除操作也像關系數據庫的操作一樣,直接給cn即可,這是因為我們在person類中setCn()方法內寫了dn的生成函數,這樣ODM才能根據被@Id所注釋的dn來找到LDAP中的entry并執(zhí)行刪除操作。
  3. 我們在Person類中寫了Name類型的dn值的構建方法,但是我一開始按照官網的代碼來寫,總是出問題,在stackOverFlow中找到了答案。鏈接在這里。
  4. 想要更深入的了解,可以參考翻譯的官方文檔。了解更自由更個性化的操作。

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


注:相關教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 瑞丽市| 上饶县| 云阳县| 万山特区| 灯塔市| 元朗区| 长泰县| 安西县| 康保县| 抚顺市| 汉寿县| 应城市| 新田县| 土默特左旗| 曲松县| 巫山县| 新沂市| 张家川| 郁南县| 双辽市| 固原市| 思南县| 潜江市| 手机| 宝应县| 龙里县| 丘北县| 新营市| 疏附县| 甘肃省| 五家渠市| 上杭县| 胶南市| 夏河县| 图木舒克市| 永和县| 上高县| 射洪县| 互助| 五峰| 通渭县|