python - Django:默认执行不区分大小写的查找

标签 python django django-models django-orm

默认情况下,我需要对 username 执行不区分大小写的查询 使用 Django Auth 框架时。

我尝试通过编写 Queryset 的自定义子类来解决这个问题 并覆盖 _filter_or_exclude 方法,然后使用它 用户模型的自定义管理器中的子类-

from django.db.models import Manager
from django.db.models.query import QuerySet
from django.contrib.auth.models import UserManager

class MyQuerySet(QuerySet):
    def _filter_or_exclude(self, negate, *args, **kwargs):
        if 'username' in kwargs:
            kwargs['username__iexact'] = kwargs['username']
            del kwargs['username']
        return super(MyQuerySet, self)._filter_or_exclude(negate, *args, **kwargs)

class MyUserManager(UserManager):
    def get_query_set(self):
        return MyQuerySet(self.model)

User.objects = MyUserManager()

但是这种方法不起作用,当我 尝试执行 User.objects.get(username='Foo')

如有任何帮助,我们将不胜感激。

更新:我包含了我遇到的确切错误。

/usr/lib/python2.5/site-packages/django/db/models/query.py in get(self, *args, **kwargs)
    295         keyword arguments.
    296         """
--> 297         clone = self.filter(*args, **kwargs)
    298         num = len(clone)
    299         if num == 1:

/usr/lib/python2.5/site-packages/django/db/models/query.py in filter(self, *args, **kwargs)
    481         set.
    482         """
--> 483         return self._filter_or_exclude(False, *args, **kwargs)
    484 
    485     def exclude(self, *args, **kwargs):

/home/ghoseb/src/git/ocricket.git/ocricket/user/models.py in _filter_or_exclude(self, negate, *args, **kwargs)
     38             kwargs['username__iexact'] = kwargs['username']
     39             del kwargs['username']
---> 40         return super(MyQuerySet, self)._filter_or_exclude(negate, *args, **kwargs)
     41 
     42 class MyUserManager(UserManager):

/usr/lib/python2.5/site-packages/django/db/models/query.py in _filter_or_exclude(self, negate, *args, **kwargs)
    499             clone.query.add_q(~Q(*args, **kwargs))
    500         else:
--> 501             clone.query.add_q(Q(*args, **kwargs))
    502         return clone
    503 

/usr/lib/python2.5/django/db/models/sql/query.py in add_q(self, q_object, used_aliases)

/usr/lib/python2.5/django/db/models/sql/query.py in add_filter(self, filter_expr, connector, negate, trim, can_reuse, process_extras)

/usr/lib/python2.5/django/db/models/sql/query.py in get_meta(self)

<type 'exceptions.AttributeError'>: 'NoneType' object has no attribute '_meta'

更新:顺便提一下,当我将 _filter_or_exclude 方法中的逻辑复制到实际的 QuerySet 类时, 它完美地工作。

最佳答案

您不想弄乱 Django 类的内部功能。这样以后每次升级都会遇到麻烦。

如果您想改变人们的身份验证方式,请编写自定义身份验证后端。

这里有两个食谱。

http://www.davidcramer.net/code/224/logging-in-with-email-addresses-in-django.html

http://www.djangosnippets.org/snippets/577/

这两个都是我们的电子邮件地址,而不是用户名。使用不区分大小写的查询而不是电子邮件查询并不难。

关于python - Django:默认执行不区分大小写的查找,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/531892/

相关文章:

python - 如何在 Django-tables2 中排序

python - django 应用程序的多个实例,django 是否支持这个

具有自定义字段表示的 json django 模型

python - 无法打开包含文件 : 'io.h' : No such file or directory

python - 选择至少有一次值的所有行

python - 如果相应(相同索引点)列 B 的条件成立,则将函数应用于列 A

django - 使用自定义字段、接收器和后端扩展 Django 用户模型

python - Django的manage.py同步数据库错误

python - 为什么这个未绑定(bind)的变量可以在 Python (pyquery) 中工作?

html - 如何将 django forms.py 选择项转换为 html 列表?