google chrome 下django用户登录失败的问题

问题:

django做的网站,用chrome访问时,有50%的概率会发生用户登录失败,request.user依然是匿名用户的情况。Firefox没问题。

分析:

痛苦了半天,静下心分析原因,发现最后页面在登录重定位后,chrome在请求页面时没有提交session。具体的访问过程是这样:

1   /accounts/login/        返回 302 FOUND,响应头中Location指向  / , 返回sessionid

2   /                              返回301 MOVED PERMANENTLY, 响应头中Location指向  /myapp/, 未返回 sessionid

3   /myapp/                   返回200 OK, 返回具体页面。

这个过程中Firefox记下了sessionid, 在第3步中提交了;而chrome未记录,在第三步中未提交,导致问题。

解决:

问题的关键在于不同浏览器处理两次重定位的不同(Firefox聪明的记下了302那次请求的会话ID,而chrome没有), 之所以有两次重定位,是因为我在urls.py直接把 / 映射到了 /myapp/,而在login.html中设置 next="/"。 如果只重定位一次,在login.html中设置 next="/myapp/",问题就迎刃而解了。

posted @ 2011-04-29 00:25  观无明  阅读(903)  评论(0编辑  收藏  举报