DJANGO⽤户登录验证完整代码1,urls.py内容:
f.urls import url
ib import admin
from myApp import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/$', views.login),
url(r'^index/$', views.index),
]
View Code
django登录注册功能
2,views.py内容
说明:
要使⽤session前提是要在settings.py⽂件中session注册了
如下:
# -*- coding: utf-8 -*-
from django.shortcuts import render, redirect, HttpResponse
# Create your views here.
# ib import auth
# ib.auth.decorators import login_required
dels import Students,Grades,User
from functools import wraps
# 说明:这个装饰器的作⽤,就是在每个视图函数被调⽤时,都验证下有没法有登录,
# 如果有过登录,则可以执⾏新的视图函数,
# 否则没有登录则⾃动跳转到登录页⾯。
def check_login(f):
@wraps(f)
def inner(request,*arg,**kwargs):
if ('is_login')=='1':
return f(request,*arg,**kwargs)
else:
return redirect('/login/')
return inner
def login(request):
# 如果是POST请求,则说明是点击登录按扭 FORM表单跳转到此的,那么就要验证密码,并进⾏保存session
hod=="POST":
username=('username')
password=('password')
user=User.objects.filter(username=username,password=password)
print(user)
if user:
#登录成功
# 1,⽣成特殊字符串
# 2,这个字符串当成key,此key在数据库的session表(在数据库存中⼀个表名是session的表)中对应⼀个value
# 3,在响应中,⽤cookies保存这个key ,(即向浏览器写⼀个cookie,此cookies的值即是这个key特殊字符)
request.session['is_login']='1'# 这个session是⽤于后⾯访问每个页⾯(即调⽤每个视图函数时要⽤到,
即判断是否已经登录,⽤此判断)# request.session['username']=username # 这个要存储的session是⽤于后⾯,每个页⾯上要显⽰出来,登录状态的⽤户名⽤。
# 说明:如果需要在页⾯上显⽰出来的⽤户信息太多(有时还有积分,姓名,年龄等信息),所以我们可以只⽤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=('username')
user_id1=('user_id')
# 使⽤user_id去数据库中到对应的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','匿名⽤户'})
View Code
3,models.py内容
from django.db import models
class User(models.Model):
username=models.CharField(max_length=16)
password=models.CharField(max_length=32)
View Code
4,login.html内容
<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>
View Code
5,这是index.html的内容
<body>
<!-- {%for student in students_list%}
{{student.sname}}--{{student.sage}}
<br>
{%endfor%} -->
<h1>这是⼀个index页⾯</h1>
<p>欢迎:{{user.username}}--{{user.password}}</p>
</body>
View Code
如果登录成功了,则会跳转到index.html页⾯:
页⾯显⽰如下:
注明:
,以下截图是我们事先保存到数据库中的username和password
注明:
6,可以查看浏览器保存的session如下截图,
则数据库⾥保存的则是此key对应的value,如下截图:
说明:key 就是我们在视图函数中的is_login 值就是1
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论