第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Go/Ldap 獲取用戶的主要組

Go/Ldap 獲取用戶的主要組

Go
翻過高山走不出你 2023-02-21 15:50:39
我正在使用 go/ldap 查詢我的活動(dòng)目錄以獲取特定用戶的所有組,該功能正在運(yùn)行但不返回主要組,如域用戶。代碼示例package mainimport (   "encoding/json"   "errors"   "fmt"   "github.com/go-ldap/ldap/v3"   "github.com/techoner/gophp"   "handlers"   "log"   "reflect"   "strconv"   "strings")func main(){      conn, err := connect(bindServer,BindPort)      if err != nil {         log.Printf("Failed to connect to AD/LDAP with error: %s", err)         return nil, fmt.Errorf("Failed to connect to AD/LDAP with error: %s", err)      }      errBind := conn.Bind(bindUser, bindPWD)      if errBind != nil {         if isLdapDebug {            log.Printf("Failed to bind to AD/LDAP with error: %s", errBind)         }         return nil, fmt.Errorf("Failed to bind to AD/LDAP with error: %s", errBind)      }      searchRequest := ldap.NewSearchRequest(         DC=domain,DC=local,         ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, 0, false,         fmt.Sprintf("(&(objectClass=user)(sAMAccountName=%s))", administrator),         []string{"dn"},         nil,      )      sr, err := conn.Search(searchRequest)      if err != nil {         return nil, err      }      if len(sr.Entries) != 1 {         return nil, errors.New("User does not exist")      }      userdn := sr.Entries[0].DN      log.Printf("USER DN IS =%s", userdn)      searchRequest = ldap.NewSearchRequest(         DC=domain,DC=local,         ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, 0, false,         fmt.Sprintf("(&(objectClass=group)(member=CN=Administrator,CN=Users,DC=domain,DC=local))"),         []string{"cn"}, // can it be something else than "cn"?         nil,      )輸出[Administrators Schema Admins Enterprise Admins Domain Admins Group Policy Creator Owners gteste1 gtest2]這些組已正確返回,但缺少主要組。有什么方法可以返回特定用戶的所有組,包括主要組?
查看完整描述

2 回答

?
aluckdog

TA貢獻(xiàn)1847條經(jīng)驗(yàn) 獲得超7個(gè)贊

主要群體不同。您必須查看primaryGroupId用戶的屬性,然后搜索其primaryGroupToken屬性中具有該值的組。

在大多數(shù)情況下,primaryGroupId將是513,它對(duì)應(yīng)于 Domain Users 組。


查看完整回答
反對(duì) 回復(fù) 2023-02-21
?
呼喚遠(yuǎn)方

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊

使用 lib 在 go 中查找主要組


github.com/go-ldap/ldap/v3

我不得不使用這個(gè)代碼示例:


userdn := sr.Entries[0].DN

groups := []string{}

searchRequest = ldap.NewSearchRequest(

   data.Record.LdapSuffix,

   ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, SearchTimelimit, false,

   fmt.Sprintf("(&(objectCategory=person)(objectClass=user)(primaryGroupID=513)(sAMAccountName=%s))", ldap.EscapeFilter(username)),

   []string{"primaryGroupID"}, 

   nil,

)

sr, err = conn.Search(searchRequest)

if err != nil {

   continue

}


if len(sr.Entries) > 0 {

   primaryGroup := sr.Entries[0].GetAttributeValue("primaryGroupID")

   if primaryGroup == "513" {

      if searchGroup == "Domain Users" {

         return true

      }

   }

}


查看完整回答
反對(duì) 回復(fù) 2023-02-21
  • 2 回答
  • 0 關(guān)注
  • 306 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)