一、Pythonldap安装
Python-ldap是Python编程语言的LDAP接口。它允许Python程序访问LDAP目录服务器。在使用Python-ldap之前,需要对其进行安装。
使用pip工具进行安装:
pip install python-ldap
如果想从源代码进行安装,可以从Python-ldap的官方网站上下载并安装:
tar xvfz python-ldap.tgz
cd python-ldap-X.Y.Z
python setup.py build
python setup.py install
二、Python ldap3 查询 用户
使用Python ldap3库中的Connection.search()方法可以进行LDAP的搜索。以下为一个ldap查询的示例:
import ldap3
server = ldap3.Server('example.com', use_ssl=True)
conn = ldap3.Connection(server, user='cn=admin,dc=example,dc=com', password='password')
with conn:
conn.search(
search_base='ou=People,dc=example,dc=com',
search_filter='(uid=jdoe)',
search_scope=ldap3.SEARCH_SCOPE_WHOLE_SUBTREE,
attributes=ldap3.ALL_ATTRIBUTES)
if conn.entries:
user_dn = conn.entries[0].entry_dn
print(user_dn)
三、Pythonldap同步group
Python ldap3库也可以用来同步组信息。使用Connection.extend.microsoft.add_members_to_groups()方法可以添加成员到组中:
import ldap3
server = ldap3.Server('example.com', use_ssl=True)
conn = ldap3.Connection(server, user='cn=admin,dc=example,dc=com', password='password')
with conn:
conn.extend.microsoft.add_members_to_groups(
group_dn='cn=group,ou=Groups,dc=example,dc=com',
members_dns=['cn=jdoe,ou=People,dc=example,dc=com'])
四、Python ldap3文档
Python ldap3文档提供了详细的使用指南和API文档,以及示例代码和FAQ等信息。可以从Python ldap3官方网站上查看:https://ldap3.readthedocs.io/en/latest/
五、Python ldapsearch
ldapsearch是一个命令行工具,用于搜索和显示LDAP目录信息。Python ldap3库可以通过Connection.search()方法实现类似的功能:
import ldap3
server = ldap3.Server('example.com', use_ssl=True)
conn = ldap3.Connection(server, user='cn=admin,dc=example,dc=com', password='password')
with conn:
conn.search(
search_base='dc=example,dc=com',
search_filter='(objectClass=*)',
search_scope=ldap3.SEARCH_SCOPE_BASE_OBJECT)
六、Python ldap3中文文档
Python ldap3文档提供了中文版本,提供了完成信息,可以查看:https://ldap3-cn.readthedocs.io/zh_CN/latest/
七、Python ldap3 读取用户dn
使用Python ldap3库中的Connection.search()方法可以查询用户dn:
import ldap3
server = ldap3.Server('example.com', use_ssl=True)
conn = ldap3.Connection(server, user='cn=admin,dc=example,dc=com', password='password')
with conn:
conn.search(
search_base='ou=People,dc=example,dc=com',
search_filter='(uid=jdoe)',
search_scope=ldap3.SEARCH_SCOPE_WHOLE_SUBTREE,
attributes=['dn'])
if conn.entries:
user_dn = conn.entries[0]['dn'].value
print(user_dn)
八、Python ldap3 统计ad数据
使用Python ldap3库的一些方法可以方便地统计获得LDAP目录中的数据,如下所示:
import ldap3
server = ldap3.Server('example.com', use_ssl=True)
conn = ldap3.Connection(server, user='cn=admin,dc=example,dc=com', password='password')
with conn:
conn.search(
search_base='dc=example,dc=com',
search_filter='(objectClass=*)',
search_scope=ldap3.SEARCH_SCOPE_BASE_OBJECT,
attributes=['numSubordinates', 'namingContexts'])
naming_contexts = conn.entries[0]['namingContexts'][0].value
num_users = int(conn.entries[0]['numSubordinates'].value) - 2
print('Naming contexts:', naming_contexts)
print('Number of users:', num_users)
原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/199533.html