郑统京 发表于 2022-11-3 00:15:17

如何通过Django操作session

# session操作
session数据是保存在服务端的,给客户端返回的是一个随机字符串
    浏览器保存形式为session_id:随机字符串(键)      session数据表中的形式为随机字符串(键):随机字符串(数据)

1、在默认情况下操作session的时候需要django默认一张django_session表
   数据库迁移命令的时候:makemigrirations migrate
      django会自动创建很多表 django_session就是其中一张[设置session]
request.session['key'] =value

def set_session(request):
    request.set_session['hobby']='girl'
    """
    内部发生了哪些事情:
      1、django内部会随机生成一个字符串(一开自己设置的键)
      2、django内部会自动将随机字符串和对应的数据存储到django_session表中
            a:先在内存中产生操作数据的缓存
            b:在响应结果django中间件的时候才真正的操作数据库
      3、将产生的随机字符串(键)返回给客户端浏览器保存
    """
    return HttpResponse('嘿嘿嘿’)[获取session] 和cookie差不多
request.session.get('key')

def get_session(request):
    request.get_session.get('hobby')
    """
    内部发发生了那些事情?
      1、自动从浏览器请求中获取session_id对应的字符串
      2、拿着该字符串去django表中查找相对应的数据
      3、如果比对上了,则将数据取出来并以字典的形式封装到request.session中
         如果比对不上,则request.session.get()返回为None
"""
    return HttpResponse('嘿嘿嘿’)[设置过期时间]
与cookie不同cookie在set_cookie(key=value,max_age=5)就可以了request.session.set_expiry()
    括号内可以放四种类型的参数
      1、直接放整数 多少秒[常用]
      2、日期对象   到指定日期就失效[常用]
      3、0      一旦当前浏览器窗口关闭就立刻失效[这个策略暂时没有了]
      4、不写      就取决于django内部全局session默认时间
[清除session]
request.session.delete() #只删服务端的 客户端的不删
request.session.flush() # 浏览器和服务端都清空[推荐使用]

def del_session(request):
    request.session.flush()
    return HttpResponse('删除了')django_session表中的数据条数取决于浏览器
(当session过期的时候可能会出现多条数据对应一个浏览器,但是该情况不会持续很久,内部会自动清除过期数据,也可以通过代码清楚)
    [同一个计算机同一个浏览器只会有一条数据生效,谷歌和360,IE在一起会产生多个,]
    主要是节省服务端资源django默认session过期时间是14天
    但是你可以人为的修改它
是保存在服务端的,但是session的保存位置可以有多种选择]
    1、MySQL
    2、文件里面
    3、缓存文件redis
    4、memcache
    。。。。
页: [1]
查看完整版本: 如何通过Django操作session