2021-08-03-DJ-019 django 实现用户的退出 cookies、session应用实操,带视频演示

这篇结合上一篇的cookie技术,对用户的登录加cookie,退出删除cookie,看cookie的存在与否保留session里面的用户信息,因为cookie并不支持中文,所以相关用户信息的内容保存到session里面。
源代码

我的Django专栏019阶段用户登录与退出演示

1.修改登录 视图函数

首先对用户登录的视图函数修改,去掉多余的东西文件上传和显示的参数,然后修改登录的视图函数。

import os
import uuid
from os.path import exists

from django.contrib.auth.hashers import check_password
from django.http import HttpRequest, HttpResponse, JsonResponse, HttpResponseRedirect
from django.shortcuts import render, redirect


# Create your views here.
from django.template import loader

from common.utilities import codewrite
from mainapp.httpresponsetest import cookietest
from .models import UserModel

# import django.core.files.uploadedfile import InMemoryUploadFile
def user_login(request:HttpRequest):
    error_msg=''
    if request.method=='POST':
        name=request.POST.get('name',None)
        password =request.POST.get('password',None)
        code:str=request.POST.get('code',None)


        if not code:
            error_msg='请输入验证码'
        else:
            if not all((name,password)):
                error_msg='用户名密码不能为空'
            else:
                if code.upper()!=request.session['validate_code']:
                    error_msg='验证码错误'
                else:

                    user_set=UserModel.objects.filter(name=name)
                    if  user_set.exists():
                        user1:UserModel=user_set.first()
                        if check_password(password,user1.userlogin.password) and user1.status==0:
                            request.session['login_user']={
                                'user_name':user1.name,
                                'user_id':user1.id,
                                'user_number':user1.number
                            }
                            error_msg=' 成功登录'
                            response = HttpResponseRedirect('login')#这里留着以后转到其他页面
                            token = uuid.uuid4().hex
                            response.set_cookie('token', token,
                                                max_age=2000)  # expires=datetime.datetime.now() + datetime.timedelta(minutes=1))
                            return response
                            # return redirect('/main/list')
                        elif user1.status==0:
                            error_msg='密码错误'
                        else:
                            error_msg='用户状态不正确,请联系管理员'


                    else:
                        error_msg='用户名不存在,请先注册'
    # dc=request.__dict__


    return render(request,'mainapp/login.html',locals())

关键部分是用户所有验证完成后增加cookie的阶段

user1:UserModel=user_set.first()
                        if check_password(password,user1.userlogin.password) and user1.status==0:
                            request.session['login_user']={
                                'user_name':user1.name,
                                'user_id':user1.id,
                                'user_number':user1.number
                            }
                            error_msg=' 成功登录'
                            response = HttpResponseRedirect('login')#这里留着以后转到其他页面
                            token = uuid.uuid4().hex
                            response.set_cookie('token', token,
                                                max_age=2000)  # expires=datetime.datetime.now() + datetime.timedelta(minutes=1))
                            return response

在session做了 个暂存字典,然后在cookie做了个令牌
这里准备是去到以前写的用户列表页面

2.退出登录设计

退出登录的思路就是检查cookie是否存在,存在即删除,一并删除里面的session,不存在就只删除原来的session
配合模板的验证,直接回到登录页面,先看看效果

登陆后的cookie状态
在这里插入图片描述

下拉点击退出登录
在这里插入图片描述
再看cookie和下拉栏
在这里插入图片描述

3.退出登录的视图函数代码:

def userlogout(request:HttpRequest):
    response = HttpResponseRedirect('login')

    if request.COOKIES.get('token'):
        response.delete_cookie('token')
    try:
        del request.COOKIES['token']
        del request.session['login_user']
    except:
        pass
    return response

4.对基础模板进行的修改

基础模板index.html的修改:一处是下拉的地方,设置退出一处是在head下面加了个块,用于设置部分页面的 重定向,因为不是所以页面都有重定向的,登录页面就不能这样,所以是留的块
下拉区

                              <div class="dropdown-menu dropdown-menu-end" aria-labelledby="navbarDropdown">
                                        <a class="dropdown-item" href="#!">Action</a>
                                        <a class="dropdown-item" href="#!">Another action</a>
                                        <div class="dropdown-divider"></div>
                                        <a class="dropdown-item" href="#!">登录者:{{ request.session.login_user.user_name|default:"未登录" }}</a>
                                           {% if request.session.login_user.user_name != None %}
                                               <a class="dropdown-item" href="{% url 'main:logout'  %}">退出登录</a>

                                        {% endif %}


                                    </div>
      

头部块

    <head>
        {% block metas %}

        {% endblock %}

        <meta charset="utf-8" />

5.模板的修改

其他页面填的metas block
我用用户列表的模板做的测试
三秒后重定向

{% block metas %}
        {% if request.COOKIES.token == None %}
            <meta http-equiv="refresh" content="3;url=/main/logout">
        {% endif %}
{% endblock %}

并对ontent block做相同的验证:(一个页面不能出现两个同名block所以要么模板再加个block,要么在block里面做判断)

在未登录的状态进入这个页面就会过3秒重定向到登录页,在
在这里插入图片描述
根据验证提供内容

{% block content %}
{% if request.COOKIES.token != None %}
    <p>登录者:{{ request.session.login_user.user_name }}</p>
    <table  class="table table-responsive" style="text-align: center;vertical-align: middle">
        <thead class="text-capitalize">
            <td>头像</td><td>账户</td><td>电话</td><td>年龄</td><td>账户状态</td>
        </thead>
        <tbody>
    {% for user  in  users %}
        <tr><td><img src="/media/{{ user.img1|escape }}" ></td>
            <td>{{ user.name }}</td>
            <td>{{ user.number }}</td>
            <td>{{ user.age }}</td>
            <td>{{ user.status }}</td>
         </tr>
    {% endfor %}
    </tbody>


    </table>
{% else %}
    <h3>用户未登录,3秒后进入登录页</h3>
{% endif %}

{% endblock %}

把登录函数的重定向设置到list上

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Amoor123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值