Re: [問題] Django POST部份資料呈現在redirect page

作者: uranusjr (←這人是超級笨蛋)   2014-11-21 13:43:05
※ 引述《walelile (wakaka)》之銘言:
: 我目前嘗試用Django的form做會員註冊。
: 我想實現的一個功能是,在填完表單按下送出後,
: 轉跳至新頁面,並在該頁面上呈現使用者的username & email
: 請問這部份的功能該如何實作比較合適?
: Django內建的HttpResponseRedirect只能夠接收url,
: 如果要完成我想要的功能,是要將那些資訊寫入session中還是有其他的作法?
: 謝謝指點
我可以想到四種做法,都有各自的優缺點:
1. 直接 POST 到你要跳轉的那頁
山不轉路轉,不要 redirect 問題就沒了。HTML form 的 action 參數可以控制
POST 目標。或者是你乾脆讓 POST 的結果就顯示使用者資訊就好。反正不要跳轉
就沒事。
優點:超簡單。
缺點:如果你有其他狀況需要註冊後「不」顯示這個頁面,就會比較麻煩。
另外就是使用者無法 refresh 這個頁面(因為不是 idempotent)。
2. 用 GET parameters 傳
反正你都要顯示在頁面上了,也沒什麼不能給別人看的。直接這樣:
url = ... # 看你怎麼得到跳轉目標
url += '?username={username}&email={email}'.format(
username=urllib.quote(username, safe=''),
email=urllib.quote(email, safe=''),
)
return HttpResponseRedirect(url)
然後在跳轉後的頁面用 request.GET 就可以拿到。
優點:也還滿簡單的,而且你的註冊頁可以重用,沒有上面的問題。
缺點:資料都被看光光,GET parameters 有點醜。
3. 用 status code 307
根據 HTTP 1.1,status code 307 Temporary Redirect 要求客戶端對跳轉
目標以相同 verb 重複剛剛的 request。所以你可以這樣寫
# 在某處...
from django.http.response import HttpResponseRedirect
class HttpResponseTemporaryRedirect(HttpResponseRedirect):
status_code = 307
# 這樣跳轉
return HttpResponseTemporaryRedirect(url)
這樣 client 就會把剛剛 POST 給註冊頁的資料再 POST 給跳轉目標。在目標
view 中再做處理就好了。
優點:和 2. 差不多,但沒有 GET parameters 的問題。
缺點:很舊的瀏覽器(IE 6…)不支援 307,然後你就 GG 了。
4. 用 session
放棄上面的玩法,就用 session 吧。
優點:如果你做對了基本上一定能動。
缺點:比較麻煩,而且多了一個東西要考慮,就會有更多發生錯誤的可能。
例如若使用者在你要求跳轉時不接受或發生錯誤,他的 session 資料會
處在很奇怪的狀態。
看起來是沒有特別萬能的方法,自己選吧。
作者: walelile (wakaka)   2014-11-21 14:32:00
非常感謝uranusjr大的分析,初次接觸,受益良多我應該會先用GET來做,session我要研究一下怎麼用
作者: Seudo (進擊的三笠)   2014-11-21 21:11:00
為什麼不直接用 render(request, 'profile.html') @@?profile.html {{request.user.XXXX}}
作者: walelile (wakaka)   2014-11-21 22:20:00
我從tutorial裏面看到說要做redirect來避免重複submit
作者: uranusjr (←這人是超級笨蛋)   2014-11-21 23:14:00
@Seudo 註冊完又不見得有登入...

Links booklink

Contact Us: admin [ a t ] ucptt.com