Django auth 登陸后頁面跳轉至/account/profile,修改跳轉至其他頁面
這幾天在學習django,django功能很強大,自帶的auth,基本可以滿足用戶注冊登陸登出,簡單的用戶注冊登陸系統使用django auth足矣。當然也不是拿來就能用的,需要自己寫登陸頁面的模板,也很簡單。自己嘗試了一下,發現一個問題,當驗證登陸成功后,頁面會自動跳轉到/account/profile,我並不想把頁面跳轉到這個頁面,如何修改呢?
查了一堆網頁,還是官網靠譜,很簡單,就在project的setting里加一句話就Okay!
LOGIN_REDIRECT_URL = ‘/index’
我這里是指定登陸成功后跳轉到index頁面,朋友們可以根據自己需要進行修改。就這樣就okay啦!歡呼吧,然后接着解決別的問題!
========================================================================================================================================================
Django 跳轉和重定向的方法:
跳轉和重定向很常見的場景就是登錄和注銷后返回到當前頁面。給你個登錄和注銷的例子。
比如用戶正在瀏覽一篇文章,發現下載該文章的附件需要登錄才能進行,這時候點擊登陸鏈接轉入登陸頁面,輸入用戶名密碼登陸成功以后,會自動轉回原來的那篇文章所在的頁面。(目前很多網站采用ajax方法彈出對話框登陸,效果更好一些)
怎么做呢?下面說的是django的實現,但是大多數的web framework都可以這么做。
注銷操作:
因為不需要單獨的注銷頁面,相對簡單,利用HTTP_REFERER,Django的注銷頁面這樣寫就行:
def logout_user(request):
logout(request)
return HttpResponseRedirect(request.META.get('HTTP_REFERER', '/'))
登錄操作:
登陸操作相對復雜,因為一般都有單獨的登陸頁面,如果登陸成功再取HTTP_REFERER就是登陸頁面自己的url,而不是之前的那個頁面。
可以利用django的session,在轉入登陸的時候,用的是頁面的get請求,這時候在session中記錄HTTP_REFERER,用戶輸入用戶名密碼進行登陸的時候(Post請求),從session中取出即可:
def login_user(request):
if request.method == 'GET':
#記住來源的url,如果沒有則設置為首頁('/')
request.session['login_from'] = request.META.get('HTTP_REFERER', '/')
#TODO:顯示登陸頁面,blablabla
elif request.method == 'POST':
#TODO: 用戶登錄操作,blablabla
#重定向到來源的url
return HttpResponseRedirect(request.session['login_from'])
最后的重定向,有時候需要用戶感覺到被重定向回去了,就寫個簡單的頁面告訴用戶兩秒以后跳轉,然后改改相應的login代碼就行:
<p>兩秒鍾后轉入如下鏈接,如果長時間沒有響應請直接點擊:</p>
<p><a href="{{ refresh_url }}">{{ refresh_url }}</a></p>
<meta http-equiv="refresh" content="2;url={{ refresh_url }}">