7

我对 Django 很陌生(从 1.3 开始)。在构建应用程序时,我从第一天开始就使用新的基于类的通用视图,使用内置类的组合并在需要添加到上下文的地方对它们进行子类化。

现在我的问题是,我需要回到我的视图,并且只有登录用户才能访问它们。我找到的所有文档都显示了如何使用旧的功能通用视图来做到这一点,而不是基于类的视图。

这是一个示例类:

class ListDetailView(DetailView):
    context_object_name = "list"

    def get_queryset(self):
        list = get_object_or_404(List, id__iexact=self.kwargs['pk'])
        return List.objects.all()

    def get_context_data(self, **kwargs):
        context = super(ListDetailView, self).get_context_data(**kwargs)
        context['subscriber_list'] = Subscriber.objects.filter(lists=self.kwargs['pk'])
        return context

如何向 django 的新的基于类的视图添加身份验证?

4

3 回答 3

19

还有一个身份验证混合选项,您可以从中派生视图类。所以使用来自 brack3t.com 的这个 mixin

class LoginRequiredMixin(object):

    @method_decorator(login_required)
    def dispatch(self, *args, **kwargs):
        return super(LoginRequiredMixin, self).dispatch(*args, **kwargs)

然后,您可以创建新的“需要身份验证”视图,如下所示:

from django.views.generic import DetailView

class MyDetailView(LoginRequiredMixin, DetailView):
    ....

无需其他添加。感觉很像不重复自己。

于 2012-04-24T19:41:01.173 回答
6

文档中有一个关于装饰基于类的视图的部分——如果你只想使用旧的login_required等,那就是要走的路。

于 2011-07-08T19:54:13.907 回答
4

我正在描述一种装饰任何 ListView 的方法:

class MyListView(ListView):
    decorator = lambda x: x

    @method_decorator(decorator)
    def dispatch(self, request, *args, **kwargs):
       return super(MyListView, self).dispatch(request, *args, **kwargs)

像这样编写基于类的视图后,您可以直接将任何基于函数的装饰器插入到 url 中。

url(r'^myurl/$', MyListView.as_view(decorator=login_required))
于 2012-03-29T21:06:44.197 回答