gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 22:24:09 26 4
gpt4 key购买 nike

默认情况下,我需要对 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com