2

我正在编写一个 django 登录视图,它重新使用通用的登录视图来完成大部分繁重的工作,但之后我会处理一些细节:

COMPANY_COOKIE = 'last_login_company_id'

def login(request, *args, **kwargs):
    initial_company_id = request.COOKIES[COMPANY_COOKIE] if COMPANY_COOKIE in request.COOKIES else None
    def makeCompanyAuthenticationForm(*args, **kwargs):
        kwargs.setdefault('initial', {})
        initial = kwargs['initial']
        initial['company'] = initial_company_id
        return CompanyAuthenticationForm(*args, **kwargs)

    kwargs['authentication_form'] = makeCompanyAuthenticationForm
    response = django_login(request, *args, **kwargs)

    if request.method == 'POST' and request.user.is_authenticated():
        request.session['user_menu'] = get_user_menu()
        if 'company' in request.POST:
            log.debug("Storing user company %s in cookie %s", request.POST['company'], COMPANY_COOKIE)
            response.set_cookie(COMPANY_COOKIE, request.POST['company'])
        request.session.save()
    return response

撇开任何关于在我的自定义表单中设置默认公司的机制的评论,我想知道为什么我COMPANY_COOKIE的没有被设置。

我正在使用设置为 的 Django 调试工具栏INTERCEPT_REDIRECTS并且True可以看到正在调用我的日志语句。如果我在 set_cookie 之后插入一个 pdb.set_trace(),我可以看到 response.cookies 包含我的公司 ID cookie。但是,我的浏览器没有它。在 DjDT 中,我可以看到我的请求的 COOKIES 变量不包含我的 cookie,而在 chrome 的存储检查器中,我看到了同样的事情;任何地方都没有last_login_company_id饼干。

为什么不设置这个?

4

1 回答 1

1

简单的答案;django-debug-toolbar 中有一个错误:

http://github.com/robhudson/django-debug-toolbar/issues/#issue/6

当intercept_redirects 被禁用时,这一切都有效。

于 2010-09-15T21:40:44.900 回答