DJANGO用户登录验证完整代码

Posted 2mei

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DJANGO用户登录验证完整代码相关的知识,希望对你有一定的参考价值。

 

1,urls.py内容:

技术分享图片
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),
]
View Code

2,views.py内容

说明:

  要使用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
# 说明:这个装饰器的作用,就是在每个视图函数被调用时,都验证下有没法有登录,
# 如果有过登录,则可以执行新的视图函数,
# 否则没有登录则自动跳转到登录页面。
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表单跳转到此的,那么就要验证密码,并进行保存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在数据库的session表(在数据库存中一个表名是session的表)中对应一个value
            # 3,在响应中,用cookies保存这个key ,(即向浏览器写一个cookie,此cookies的值即是这个key特殊字符)
            request.session[is_login]=1
            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})
    return render(request,index.html)
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,如果没有登录前,直接输入http://localhost:8000/index/  则会自动跳转到login页面

       如果登录成功了,则会跳转到index.html页面,以下截图是我们事先保存到数据库中的username和password

技术分享图片

 

 6,可以查看浏览器保存的session如下截图,

技术分享图片

则数据库里保存的则是此key对应的value,如下截图:

技术分享图片

 

说明:key 就是我们在视图函数中的is_login   值就是1 

 技术分享图片

 

以上是关于DJANGO用户登录验证完整代码的主要内容,如果未能解决你的问题,请参考以下文章

简易登录表单的制作,包括用户名密码随机验证码(代码完整,复制即用)

Django在CBV中使用,用户登录验证组件

Express实战 - 应用案例- realworld-API - 路由设计 - mongoose - 数据验证 - 密码加密 - 登录接口 - 身份认证 - token - 增删改查API(代码片段

Django身份验证和Ajax - 需要登录的URL

教程4 - 验证和权限

VSCode自定义代码片段——git命令操作一个完整流程