1.下载Go语言操作LDAP的第三方库gopkg.in/ldap

go get github.com/go-ldap/ldap/v3

2.连接LDAP

 //连接
    l, err := ldap.DialURL("ldap://localhost:389")

    if err != nil {
        log.Fatal(err)
    } else {
        log.Printf("Connect LDAP Server succeeded")
    }
    defer l.Close()

3.身份认证

在这里插入代码片
 //身份认证
    _,err=l.SimpleBind(&ldap.SimpleBindRequest{

        Username: "cn=admin,dc=example,dc=com",
      
        Password: "123456",
    })
    if err!=nil {
        log.Fatal("Failed to bind: %s\n", err)
    } else {
        log.Printf("Login succeeded")
    }
   

4.执行查询

 //查询
    searchRequest := ldap.NewSearchRequest(
        "cn=admin,dc=example,dc=com", // The base dn to search
        ldap.ScopeWholeSubtree, 
        ldap.NeverDerefAliases, 
        0, 
        0,
        false,
        "(objectClass=*)",
        []string{"DN", "cn","dc","ou","objectClasss"},                   
        nil,
    )

    sr, err := l.Search(searchRequest)
    if err != nil {
        log.Fatal(err)
    }

    //fmt.Println(len(sr.Entries)) //查询结果长度
    //fmt.Println(len(sr.Entries[0].Attributes)) //第一个结果的属性数目
    //fmt.Println(sr.Entries[0].Attributes[0].Name)//第一个结果的第一个属性名称


    //遍历结果数组
    for index,entry:=range sr.Entries{
        fmt.Println(index,entry.DN)
    }
 
Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐