J'ai un enregistrement divisé en quelques étapes. La page actuelle est enregistrée en session. Mais mes fonctions se comportent bizarrement. Si nous actualisons step1
, la variable dans la session est remplacée par 2
et est remplacée par step2
. Dans cette étape, je vérifie si l'utilisateur a déjà été créé, et si ce n'est pas le cas, réduis step
à 1 et redirige vers la vue en espérant que le step
sera rendu. Mais au lieu que je reçoisComportement de session et de redirection étrange
def my_rte_landing(request):
step = request.session.get("step", request.REQUEST.get("step", 1))
logging.debug("my_rte_landing top step: %s" % step)
if request.method == "POST":
(... next steps ...)
else:
if step == 1:
logging.debug("step 1")
html = render_step1(request)
request.session["step"] = 2
return render_to_response('socialauth/login_page.html',{'html': html,}, context_instance=RequestContext(request))
else:
logging.debug("step 2")
logging.debug("step2, step: %s" % request.session.get('step'))
new_user = True
new_user_id = request_user_uid(request, request.user.id)
html = render_step2(request)
request.session["step"] = 3
return render_to_response('socialauth/login_page.html',
{'html': html}, context_instance=RequestContext(request))
ici est ma fonction de vérification pour l'existence de l'utilisateur:
def request_user_uid(request, user_id):
if request.session['step'] == 2:
logging.debug("1 here")
id = get_user_id(user_id)
if id:
logging.debug("2. here")
return id
request.session['step'] = 1
logging.debug("3. here")
logging.debug("step: %s" % request.session.get('step'))
return HttpResponseRedirect(reverse('my_rte_landing'))
Et mon debug ressemble à ceci (je visite la page pour la première fois, ne pas vous déconnecter, rafraîchir , je peux voir l'étape 2, rafraîchissement, étape encore 2)
2010-11-30 17:11:21,434 DEBUG my_rte - nie zalogowany
2010-11-30 17:11:23,245 DEBUG my_rte_landing top step: 1
2010-11-30 17:11:23,246 DEBUG step 1
(first refresh)
2010-11-30 17:11:34,626 DEBUG my_rte_landing top step: 2
2010-11-30 17:11:34,626 DEBUG step 2
2010-11-30 17:11:34,626 DEBUG step2, step: 2
2010-11-30 17:11:34,626 DEBUG 1 here
2010-11-30 17:11:34,628 DEBUG 3. here
2010-11-30 17:11:34,628 DEBUG step: 1
(second refresh)
2010-11-30 17:11:59,523 DEBUG my_rte_landing top step: 3
2010-11-30 17:11:59,523 DEBUG step 2
2010-11-30 17:11:59,524 DEBUG step2, step: 3
Pouvez-vous publier les URL? – Seitaridis