我正在使用 django-auth-ldap 并且我正在嘗試從 LDAP 服務器獲取所有用戶,我沒有找到這樣做的方法,身份驗證在后端作業,這是我的代碼
@api_view(['GET'])
def users(request):
l = ldap.initialize(backend.AUTH_LDAP_SERVER_URI)
l.simple_bind_s(backend.AUTH_LDAP_BIND_DN, backend.AUTH_LDAP_BIND_PASSWORD)
users = LDAPBackend().populate_user('*') #this line is returning None
l.unbind_s()
print (users)
serializer = userSerializer(users, many=True)
return Response(serializer.data)
我知道那條線不正確 LDAPBackend().populate_user('*')
但我真的需要讓所有用戶都擁有這樣的東西:(conn.search('ou=users, dc=example,dc=com', '(objectclass=person)', attributes=['uid', 'cn', 'givenName', 'sn', 'gidNumber'])
這就是我對另一個名為 ldap3 的庫所做的)
謝謝
uj5u.com熱心網友回復:
你可以在下面做這樣的事情
def get_users():
conn = ldap.initialize(LDAP_URL)
results = conn.search_s(GROUP_DN, ldap.SCOPE_ONELEVEL, '(cn=*)')
# get all non-empty uniqueMember of all groups (list of list), flattern the list and get only unique value
users_dn = set(list(chain.from_iterable(filter(lambda x: x, [x[1].get('uniqueMember') for x in results]))))
users = [x.split(',')[0].split('=')[1] for x in users_dn]
return users
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/370651.html
標籤:Python 姜戈 LDAP django-auth-ldap
