Please see the solution in my blog : 
http://pragmaticobjects.org/index.php?itemid=23

Let me know if that doesn't work for you.

Kevin Hoang Le

On Apr 11, 4:39 pm, "James Bennett" <[EMAIL PROTECTED]> wrote:
> On 4/11/07, jeffhg58 <[EMAIL PROTECTED]> wrote:
>
> > The only problem I am having is when Ilogoutand either hit the back
> > button or go to my home
> > page from the browser it does not give me the login prompt window.
>
> This is kind of tricky and exposes a pseudo-bug in Django.
>
> What's happening is this:
>
> 1. At the time the request starts, you're logged in, and so the
> AuthenticationMiddleware sets 'request.user' so that it returns your
> User object, which in turn returns True on an 'is_authenticated()'
> check.
> 2. At the time that you hit the 'login_required' decorator, you
> haven't yet hit the view code which logs youout, so you pass that
> check and don't get redirected to a login form.
> 3. When the 'logout' view logs youout, it doesn't reset
> 'request.user', so any template rendering which uses an
> 'is_authenticated()' check will get confused (this is the bug).
> 4. When the response comes back to your browser, it includes cookie
> headers which make the logout persist.
>
> So if you use the 'logout' view and return a template directly from
> it, the template may "think" you're logged in even though you're not
> (you can't actually do anything which requires authentication, it's
> just that 'request.user' wasn't updated before the template rendered).
> If you instead have 'logout' redirect to another URL, you'll see
> everything working intuitively, because that involves a new request
> which startsoutwith 'request.user' as an AnonymousUser.
>
> Hitting the back button probably causes the behavior you're seeing
> because some browsers don't actually hit the server on a "back" and
> instead reload the page from cache, which means you'll see the same
> thing you saw when you were logged in previously.
>
> The confusing aspects of this can be handled by having Django reset
> 'request.user' on authentication changes (it also doesn't do so on
> login, which can be somewhat counterintuitive when using things like
> the registered comments model), so I'll file a ticket for that.
>
> --
> "Bureaucrat Conrad, you are technically correct -- the best kind of correct."


--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to