2010-11-30 4 views
0

登録はいくつかのステップに分かれています。現在のページはセッションに保存されます。しかし、私の機能は変です。 step1を更新すると、セッション内の変数が2に変更され、代わりにstep2が読み込まれます。このステップでは、ユーザーが既に作成されているかどうかを確認していて、stepを1に減らしていない場合は、stepがレンダリングされることを望むビューにリダイレクトします。しかし、その代わりに、私は奇妙なリダイレクトとセッションの動作

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)) 

を得ていることはここでは、ユーザの存在を確認する私の機能です:

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')) 

そして、私のデバッグは(私が、初めてのページを訪問しログインしていない、リフレッシュしています。このようになります。私は、STEP2、リフレッシュ、まだ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

あなたはURLを投稿できますか? – Seitaridis

答えて

0

あなたはステップをリセット..

 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 

だから、あなたは戻り値ミックス

0

...あなたは非常に次のものが戻って3に設定されている)(request_user_uidのステップ== 1を設定するかもしれないが:

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 

および機能の使用状況を:new_user_id = request_user_uid(request, request.user.id) # contains HttpResponseRedirect instance それは意図的ですか?

+0

私は、そこにリダイレクトするのではなく、 'new_user_id'に' HttpResponseRedirect'インスタンスしかありません – user461342