【发布时间】:2018-11-13 23:43:31
【问题描述】:
我已按照 django-ldap README 中的说明进行操作,但我似乎无法让 django-ldapdb 表现得像在进行 LDAP 查询一样。以下内容已在使用 Python 3.7 的全新 Django v.2.1.2 实例上进行编辑:
更改为settings.py:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
},
'ldap': {
'ENGINE': 'ldapdb.backends.ldap',
'NAME': 'ldaps://my.server',
'USER': 'cn=some user',
'PASSWORD': 'somePassword',
}
}
DATABASE_ROUTERS = ['ldapdb.router.Router']
新models.py:
class MyPerson(ldapdb.models.Model):
base_dn = "ou=people,dc=ucsf,dc=edu"
object_classes = ['person', 'myPerson]
uid = fields.IntegerField(db_column='uid')
displayname = fields.CharField(db_column='displayname')
eid = fields.CharField(db_column='eid')
def __str__(self):
return str(self.uid)
def _unicode__(self):
return str(self.uid)
我认为的查询。首先我尝试了:
result = MyPerson.objects.filter(uid=99894)
然后我尝试了:
result = MyPerson.objects.using('ldap').filter(uid=99894)
在 PyCharm 的调试器中运行 Django 开发服务器,我可以看到 result 接收到带有以下消息的 QuerySet:
Unable to get repr for <class 'django.db.models.query.QuerySet'>
我所说的“消息”是什么意思。老实说,我不确定,但调试器显示:
此外,尽管QuerySet 的db 成员似乎是“ldap”,而query 成员显示的是SQL 查询,而不是LDAP 过滤器。当我通过 URL 路由、视图、查询和结果跟踪 HTTP 请求时,我从未见过它进行任何类型的 LDAP 相关调用。为了更好地衡量,我破坏了 LDAP 绑定密码,但没有收到绑定错误。很确定我错过了一些让 Django 知道我现在想使用 LDAP 的东西......我只是不知道那是什么。
【问题讨论】:
-
您收到 repr 错误可能是因为您的 str 方法应该返回一个字符串:
def __str__(self): return str(self.uid) -
@UkuLoskit ,感谢您的建议,但没有任何区别。我知道 uid 成员是一个整数变量, str 的用户期待一个字符串。这应该以任何一种方式纠正。但是,是什么让你想到我的问题? (顺便说一句,更改我上面的原始代码以反映此更改)
标签: python django ldap django-ldapdb