糟糕的搜索过滤器

时间:2016-03-29 15:02:17

标签: python python-ldap

我试图从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

1 个答案:

答案 0 :(得分:0)

您的搜索过滤器实际上是不好的。

|字符用于在OR语句中连接多个条件。例如,如果您想查找姓氏为"史密斯"," jones"或" baker"的人,您将使用此过滤器:

(|(lastname=smith)(lastname=jones)(lastname=baker))

但是,您的过滤器只有一个条件,因此|字符无法连接在一起。将您的过滤器更改为此,它应该可以工作:

"(uid=" + username + "\*)"

顺便问一下,你想用反斜杠和星号做什么?您是否在寻找用户名实际上以星号结尾的人?