您好,登錄后才能下訂單哦!
使用session保持用戶登陸連接
在 view 中 login() 視圖函數里增加如下語句
不允許重復登錄語句
if request.session.get('is_login',None): return HttpResponseRedirect(reverse('index'))
一旦用戶名和密碼輸入正確,就往 session 字典內寫入用戶狀態和數據
request.session['is_login'] = True request.session['user_id'] = db_user.id request.session['user_name'] = db_user.name
對于 logout() 方法進行編寫。
def logout(request): if not request.session.get('is_login', None): # 如果本來就未登錄,也就沒有登出一說 return redirect("/index/") request.session.flush() # 或者使用下面的方法 # del request.session['is_login'] # del request.session['user_id'] # del request.session['user_name'] return redirect("/index/")
使用 flush() 方法清除數據比較安全,但是不能保存 session 中的私貨
對于 HTML 文件進行改寫
{% if request.session.is_login %} <li><a href="#" rel="external nofollow" >當前在線:{{ request.session.user_name }}</a></li> <li><a href="/logout/" rel="external nofollow" >登出</a></li> {% else %} <li><a href="/login/" rel="external nofollow" >登錄</a></li> <li><a href="/register/" rel="external nofollow" >注冊</a></li> {% endif %}
以上這篇Django中使用session保持用戶登陸連接的例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。