2010-11-30 8 views
0

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 
+0

Pouvez-vous publier les URL? – Seitaridis

Répondre

0

remise à zéro de l'étape ..

 new_user_id = request_user_uid(request, request.user.id) 
     # request.session["step"] is currently set to 1 ... however the 
     # following lines undo that... 
     html = render_step2(request) 
     request.session["step"] = 3 

Ainsi, alors que vous pouvez définir étape == 1 dans request_user_uid() la chose suivante vous est fixé de nouveau à 3 ...

0

vous mélangez des valeurs de retour:

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 #### !!!! returning some value 

     request.session['step'] = 1 
     logging.debug("3. here") 
     logging.debug("step: %s" % request.session.get('step')) 
    return HttpResponseRedirect(reverse('my_rte_landing')) #### !!!! HttpResponseRedirect 

et utilisation de la fonction : new_user_id = request_user_uid(request, request.user.id) # contains HttpResponseRedirect instance est-ce intentionnel?

+0

Je veux dire, vous n'y arrivez pas, seule l'instance 'HttpResponseRedirect' dans' new_user_id' – user461342