django用戶登錄驗證的完整示例代碼
1,urls.py內(nèi)容:
from django.conf.urls import url from django.contrib import admin from myApp import views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^login/$', views.login), url(r'^index/$', views.index), ]
2,views.py內(nèi)容
說明:
要使用session前提是要在settings.py文件中session注冊了
如下:

# -*- coding: utf-8 -*-
from django.shortcuts import render, redirect, HttpResponse
# Create your views here.
# from django.contrib import auth
# from django.contrib.auth.decorators import login_required
from myApp.models import Students,Grades,User
from functools import wraps
# 說明:這個裝飾器的作用,就是在每個視圖函數(shù)被調(diào)用時,都驗證下有沒法有登錄,
# 如果有過登錄,則可以執(zhí)行新的視圖函數(shù),
# 否則沒有登錄則自動跳轉(zhuǎn)到登錄頁面。
def check_login(f):
@wraps(f)
def inner(request,*arg,**kwargs):
if request.session.get('is_login')=='1':
return f(request,*arg,**kwargs)
else:
return redirect('/login/')
return inner
def login(request):
# 如果是POST請求,則說明是點擊登錄按扭 FORM表單跳轉(zhuǎn)到此的,那么就要驗證密碼,并進行保存session
if request.method=="POST":
username=request.POST.get('username')
password=request.POST.get('password')
user=User.objects.filter(username=username,password=password)
print(user)
if user:
#登錄成功
# 1,生成特殊字符串
# 2,這個字符串當成key,此key在數(shù)據(jù)庫的session表(在數(shù)據(jù)庫存中一個表名是session的表)中對應(yīng)一個value
# 3,在響應(yīng)中,用cookies保存這個key ,(即向瀏覽器寫一個cookie,此cookies的值即是這個key特殊字符)
request.session['is_login']='1' # 這個session是用于后面訪問每個頁面(即調(diào)用每個視圖函數(shù)時要用到,即判斷是否已經(jīng)登錄,用此判斷)
# request.session['username']=username # 這個要存儲的session是用于后面,每個頁面上要顯示出來,登錄狀態(tài)的用戶名用。
# 說明:如果需要在頁面上顯示出來的用戶信息太多(有時還有積分,姓名,年齡等信息),所以我們可以只用session保存user_id
request.session['user_id']=user[0].id
return redirect('/index/')
# 如果是GET請求,就說明是用戶剛開始登錄,使用URL直接進入登錄頁面的
return render(request,'login.html')
@check_login
def index(request):
# students=Students.objects.all() ## 說明,objects.all()返回的是二維表,即一個列表,里面包含多個元組
# return render(request,'index.html',{"students_list":students})
# username1=request.session.get('username')
user_id1=request.session.get('user_id')
# 使用user_id去數(shù)據(jù)庫中找到對應(yīng)的user信息
userobj=User.objects.filter(id=user_id1)
print userobj
if userobj:
return render(request,'index.html',{"user":userobj[0]})
else:
return render(request,'index.html',{'user','匿名用戶'})
3,models.py內(nèi)容
from django.db import models class User(models.Model): username=models.CharField(max_length=16) password=models.CharField(max_length=32)
4,login.html內(nèi)容
<body>
<h1>歡迎登錄!</h1>
<form action="/login/" method="post">
{% csrf_token %}
<p>
用戶名:
<input type="text" name="username">
</p>
<p>
密碼:
<input type="text" name="password">
</p>
<p>
<input type="submit" value="登錄">
</p>
<hr>
</form>
</body>
5,這是index.html的內(nèi)容
<body>
<!-- {%for student in students_list%}
{{student.sname}}--{{student.sage}}
<br>
{%endfor%} -->
<h1>這是一個index頁面</h1>
<p>歡迎:{{user.username}}--{{user.password}}</p>
</body>
5,如果沒有登錄前,直接輸入http://localhost:8000/index/ 則會自動跳轉(zhuǎn)到login頁面
如果登錄成功了,則會跳轉(zhuǎn)到index.html頁面:
頁面顯示如下:

注明:
,以下截圖是我們事先保存到數(shù)據(jù)庫中的username和password

注明:
6,可以查看瀏覽器保存的session如下截圖,

則數(shù)據(jù)庫里保存的則是此key對應(yīng)的value,如下截圖:

說明:key 就是我們在視圖函數(shù)中的is_login 值就是1

總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
相關(guān)文章
Python3 操作 MySQL 插入一條數(shù)據(jù)并返回主鍵 id的實例
這篇文章主要介紹了Python3 操作 MySQL 插入一條數(shù)據(jù)并返回主鍵 id的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
Linux 發(fā)郵件磁盤空間監(jiān)控(python)
這篇文章主要介紹了Linux發(fā)郵件磁盤空間監(jiān)控功能,python實現(xiàn),需要的朋友可以參考下2016-04-04
pytorch cuda上tensor的定義 以及減少cpu的操作詳解
這篇文章主要介紹了pytorch cuda上tensor的定義 以及減少cpu的操作詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06

