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