1

我想扩展 User 模型,所以我可以放入一些额外的字段和函数(不仅是字段,请记住,否则(好吧,仍然)我可以使用 get_profile(),我认为这很难看)。

我还想在 request.user 中使用新的扩展用户模型,如下所示:

扩展用户模型:

# imports etc

class CustomUser(User):
    extra_field = ...

    def extra_function(self):
        ...

        return ...

示例使用视图:

# imports etc

def extra_function_view(request):
    print request.user.username
    print request.user.extra_field

    request.user.extra_function()

    return HttpResponse( ... )

上面的代码显然是行不通的,因为extra_field和extra_function不在User模型中。

现在我找到了一种方法来完成这个,使用身份验证后端,这有点复杂,而且我无法在 Django 1.2.3 中工作。

AUTHENTICATION_BACKENDS = (
    'myproject.auth_backends.CustomUserModelBackend',
)
...

CUSTOM_USER_MODEL = 'accounts.CustomUser'

进一步尝试了一些其他方法,例如使用信号,但没有成功。对我来说,唯一的解决方案似乎是在 Django 中调整 User 模型(这不是一个优雅的解决方案,调整 Django 的源代码,但在代码方面是一个简洁的解决方案)。

所以我正在为此寻找解决方案..以前有人这样做过吗?

现在谢谢

斯特凡

4

1 回答 1

2

您在调整身份验证后端方面处于正确的轨道上。

身份验证后端可以非常简单,这是我们在项目中使用的一个片段。

class LocalAccount(object):
    def authenticate(self, system=None, username=None, password=None):
        try:
            user = User.objects.get(system=system, alias=username)
            if user.check_password(password):
                return user
        except User.DoesNotExist:
            return None

    def get_user(self, user_id):
        'returns user'

    def get_all_permissions(self, user_obj):
        'returns user permissions'

    def has_perm(self, user_obj, perm):
        'verifies permission, remember you can hardcode these'

    def get_group_permissions(self, user_obj):
        return set() #We don't use this

    def has_module_perms(self, user_obj, app_label):
        return False

这允许您返回您希望返回的任何用户模型。只要您的用户模型基本上像 Django 的用户模型,您就不会遇到任何问题。

还要记住,扩展用户并包含应用程序将导致 Django 用户模型和您自己的用户模型都在具有模型继承的数据库中。您最好的选择是复制 Django User 模型并对其进行更改。对于我们的项目,我们甚至没有在已安装的应用程序设置中包含“auth”。

这里的概念是 Python鸭子类型。只要您创建的 User 模型具有 Django 正在寻找的相同接口(方法、字段),它是否实际上是它指定的 User 类并不重要。

于 2010-11-30T14:00:04.080 回答