使用goLang进行LDAP身份验证

时间:2016-10-06 18:32:06

标签: go ldap openldap ldap-query

我正在尝试使用goLang对LDAP服务器进行身份验证,同时尝试搜索用户。 我是goLang和LDAP的新手,所以我拉了GitHub代码。 尝试使用以下代码时,我在身份验证中遇到错误

func ExampleLDAPClient_Authenticate() {
    client := &ldap.LDAPClient{
        Base:         "cn=admin,dc=testing,dc=io",
        Host:         "52.51.245.219",
        Port:         389,
        UseSSL:       false,
        BindDN:       "cn=admin,dc=testing,dc=io",
        BindPassword: "test123",
        UserFilter:   "(uid='*api*')",
        // GroupFilter:  "(memberUid=%s)",
        Attributes: []string{"givenName", "sn", "mail", "uid"},
    }
    defer client.Close()
    username := "cn=admin,dc=testing,dc=io"
    password := "test123"
    ok, user, err := client.Authenticate(username, password)
    if err != nil {
        log.Fatalf("Error authenticating user %s: %+v", "*cn=admin,dc=testing,dc=io*", err)
    }
    if !ok {
        log.Fatalf("Authenticating failed for user %s", "*cn=admin,dc=testing,dc=io*")
    }
    log.Printf("User: %+v", user)
}
go run example.go
    2016/10/06 23:52:25 Error authenticating user *cn=admin,dc=testing,dc=io*: LDAP Result Code 201 "": ldap: finished compiling filter with extra at end: %!(EXTRA string=bmui)

注意:LDAP服务器使用http连接

任何人都可以帮我解决这个问题......

1 个答案:

答案 0 :(得分:0)

这是什么图书馆?

我使用过http://gopkg.in/ldap.v2,在我看来它运行良好(至少使用OpenLDAP服务器)。它可能值得尝试 - 它似乎是最常用的库。