-1

我正在使用 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 的库所做的)

谢谢

4

1 回答 1

1

你可以在下面做这样的事情

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
于 2021-12-01T10:35:24.320 回答