golang ldap 学习

就是一个简单的关于ldap的学习,ldap server 使用了openldap,基于docker 运行

环境准备

  • docker-compose 文件
version: "3"
services: 
  ldap:
     image: osixia/openldap:latest
     environment:
     - "LDAP_ORGANISATION=dalongrong"
     - "LDAP_DOMAIN=rongfengliang.com"
     - "LDAP_ADMIN_PASSWORD=12sROjpn*^"
     ports: 
     - 389:389
     - 636:636
  • go mod
module myldapapp
go 1.14
require (
    github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751 // indirect
    github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d // indirect
    github.com/go-ldap/ldap/v3 v3.2.3 // indirect
    gopkg.in/alecthomas/kingpin.v2 v2.2.6
)
  • main.go
package main
import (
    "fmt"
    "log"
    "gopkg.in/alecthomas/kingpin.v2"
    "github.com/go-ldap/ldap/v3"
)
var (
    ldapaddr         = kingpin.Flag("addr", "ldap addr").Default("127.0.0.1").String()
    ldapport         = kingpin.Flag("port", "ldap connect port").Default("389").Int()
    ldapusername     = kingpin.Flag("username", "ldap connect usernmae").Default("cn=admin,dc=rongfengliang,dc=com").String()
    ldapuserpassword = kingpin.Flag("password", "ldap connect password").Default("12sROjpn*^").String()
    debug            = kingpin.Flag("debug", "run with debug").Default("false").Bool()
)
func main() {
    kingpin.Parse()
    fmt.Printf("%v, %d\n", *ldapaddr, *ldapport)
    con, err := ldap.DialURL(fmt.Sprintf("ldap://%s:%d", *ldapaddr, *ldapport))
    if err != nil {
        log.Fatal("connect err:", err)
    }
    defer con.Close()
    con.Debug.Enable(*debug)
    err = con.Bind(*ldapusername, *ldapuserpassword)
    if err != nil {
        log.Fatal("bind err:", err)
    }
    searchRequest := ldap.NewSearchRequest(
        "dc=rongfengliang,dc=com",
        ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, 0, false,
        "(objectClass=*)",
        []string{"dn", "cn", "objectClass"},
        nil,
    )
    searchResult, err := con.Search(searchRequest)
    if err != nil {
        log.Println("can't search ", err.Error())
    }
    log.Printf("%d", len(searchResult.Entries))
    for _, item := range searchResult.Entries {
        item.PrettyPrint(4)
    }
}
  • 代码说明
    配置部分基于kingpin,对于ldap 的使用,首先需要connect。然后需要bind(安全),之后就是一些功能操作了(查询,更新,删除。。)
  • 运行效果

ldap 数据:

 

 

cli 参数:

 

 


运行效果:

 

 

参考资料

https://github.com/rongfengliang/golang-ldap-learning
https://github.com/go-ldap/ldap
https://github.com/alecthomas/kingpin
https://github.com/osixia/docker-openldap

posted on   荣锋亮  阅读(2321)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2019-09-12 kuma docker-compose 环境试用
2018-09-12 timescaledb 集成prometheus

导航

< 2025年3月 >
23 24 25 26 27 28 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 1 2 3 4 5
点击右上角即可分享
微信分享提示