我正在编写一个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
cookie。
为什么不设置?
答案 0 :(得分:1)
简单的回答; django-debug-toolbar中有一个错误:
http://github.com/robhudson/django-debug-toolbar/issues/#issue/6
当禁用intercept_redirects时,这一切都有效。