我试图从ldap服务器中过滤掉一些属性,但却出错了,
ldap.FILTER_ERROR: {'desc': 'Bad search filter'}
代码: -
import ldap
ldap.OPT_REFERRALS = 0
ldap_server="ldapps.test.com"
username = "testuser"
password= "" #your password
connect = ldap.open(ldap_server)
dn='uid='+username;
print 'dn =', dn
try:
result = connect.simple_bind_s(username,password)
print 'connected == ', result
filter1 = "(|(uid=" + username + "\*))"
result = connect.search("DC=cable,DC=com,DC=com",ldap.SCOPE_SUBTREE,filter1)
print result
except ldap.INVALID_CREDENTIALS as e:
connect.unbind_s()
print "authentication error == ", e
答案 0 :(得分:0)
您的搜索过滤器实际上是不好的。
|
字符用于在OR
语句中连接多个条件。例如,如果您想查找姓氏为"史密斯"," jones"或" baker"的人,您将使用此过滤器:
(|(lastname=smith)(lastname=jones)(lastname=baker))
但是,您的过滤器只有一个条件,因此|
字符无法连接在一起。将您的过滤器更改为此,它应该可以工作:
"(uid=" + username + "\*)"
顺便问一下,你想用反斜杠和星号做什么?您是否在寻找用户名实际上以星号结尾的人?