django_session方式实现登录

一、什么是session


1、上次链接说到了cookie,cookie是保存在客户端的,且明文传输,所以一些用户敏感数据放在cookie中不安全,比如说用户余额。所以session就出现了,当然session也离不开cookie
session是一组session[key] = value的组键,在生成session时,会将session_key保存到cookie中一份存在浏览器,同时也会保存的服务端一份,而session的value也保存在服务端
当用户想获取信息是,会取cookie中取session的key,拿服务端查找,如果有则返回对应的value
所以session的安全就存在于,他只在cookie中存放了 session的key,并没有任何值,值是存在服务端的

2、下面我们来看几种方法

# 创建或修改 session:
request.session[key] = value
# 获取 session:如果不存在,返回default的值
request.session.get(key,default=None)
# 删除 session
del request.session[key] # 不存在时报错

3、django里自带了一个,session表,可以自动存储session

image.png

image.png

我们需要创建一下

manage.py migrate

4、下面看一个接口,相当于伪代码

from rest_framework.decorators import api_view


@api_view(["GET", ])
def api_login(request):
    if True:
        request.session["islogin"] = "yes"  #如果登录成功,种一组cookie进去
        return JsonResponse({"code": 0, "msg": "登录成功"})

这里看已经种成功了

image.png

session表格中也多了一组数据

image.png

那现在我们登录一下

@api_view(["GET", ])
def api_is_login(request):
    if request.session.get("islogin", False):
        session_value = request.session['islogin'] #取session的值
        print(session_value)
        if session_value == "yes":
            JsonResponse({"code": 1, "msg": "显示首页"})
        else:
            return JsonResponse({"code": 0, "msg": "显示登录页"})
    return JsonResponse({"code": 0, "msg": "显示登录页"})

可以登录成功

image.png

下面我们把sessionid改一下

image.png

则返回不成功

image.png

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值