zoukankan      html  css  js  c++  java
  • 十一 Django框架,Session

    Django中默认支持Session,其内部提供了5种类型的Session供开发者使用:

    1、数据库(默认)
    2、缓存
    3、文件
    4、缓存+数据库
    5、加密cookie

    1、数据库Session,保存在数据库

    Django默认支持Session,并且默认是将Session数据存储在数据库中,即:django_session 表中。

    全局配置Session

    复制代码
    Django默认支持Session,并且默认是将Session数据存储在数据库中,即:django_session 表中。
     
    a. 配置 settings.py
     
        SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默认)数据库保存session引擎
         
        SESSION_COOKIE_NAME = "sessionid"                       # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串(默认)
        SESSION_COOKIE_PATH = "/"                               # Session的cookie保存的路径(默认)
        SESSION_COOKIE_DOMAIN = None                             # Session的cookie保存的域名(默认)
        SESSION_COOKIE_SECURE = False                            # 是否Https传输cookie(默认)
        SESSION_COOKIE_HTTPONLY = True                           # 是否Session的cookie只支持http传输(默认)
        SESSION_COOKIE_AGE = 1209600                             # Session的cookie失效日期(2周)(默认)
        SESSION_EXPIRE_AT_BROWSER_CLOSE = False                  # 是否关闭浏览器使得Session过期(默认)
        SESSION_SAVE_EVERY_REQUEST = False                       # 是否每次请求都保存Session,默认修改之后才保存(默认),默认就好
    复制代码

    使用Session

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
        print(request.session['k1'])     #获取session
        return render(request, 'app1/index.html')
    复制代码

    获取、设置、删除Session中指定数据
    request.session['k1'] 获取Session中数据,不存在报错
    request.session.get('k1',None) 获取Session中数据,不存在返回None
    request.session['k1'] = 123 设置Session中数据,存在覆盖
    request.session.setdefault('k1',123) 设置Session中数据,存在不设置
    del request.session['k1'] 删除Session中指定数据

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
        print(request.session['k1'])     #获取session
        del request.session['k1']
        return render(request, 'app1/index.html')
    复制代码

    获取Session中所有 键、值、键值对
    request.session.keys()获取Session中所有的键
    request.session.values()获取Session中所有的值
    request.session.items()获取Session中所有的键值对
    request.session.iterkeys()
    request.session.itervalues()
    request.session.iteritems()

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
        request.session['k2'] = 456      # 设置session
        request.session['k3'] = 789      # 设置session
        # print(request.session['k1'])     #获取session
    
        #
        print(request.session.keys())
        print(request.session.values())
        print(request.session.items())
    
        return render(request, 'app1/index.html')
    复制代码

    获取用户session的随机字符串,也就是session名称
    request.session.session_key获取用户session的随机字符串,也就是session名称

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
        request.session['k2'] = 456      # 设置session
        request.session['k3'] = 789      # 设置session
        # print(request.session['k1'])     #获取session
    
    
        print(request.session.session_key)
    
        return render(request, 'app1/index.html')
    复制代码

    将所有Session失效日期小于当前日期的数据在数据库删除,也就是在数据库删除过期的Session数据
    request.session.clear_expired()

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        # request.session['k1'] = 123      #设置session
        # request.session['k2'] = 456      # 设置session
        # request.session['k3'] = 789      # 设置session
        # print(request.session['k1'])     #获取session
    
    
        request.session.clear_expired()
    
        return render(request, 'app1/index.html')
    复制代码

    request.session.exists("获取当前随机字符串")检查 用户session的随机字符串 在数据库中是否

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
    
    
        a = request.session.session_key
        print(request.session.exists(a))
    
        return render(request, 'app1/index.html')
    复制代码

    request.session.delete("获取当前用户随机字符串")删除当前用户的所有Session数据

    复制代码
    from django.shortcuts import render
    from app1.models import *    #导入数据库操作模块
    from app1.biaodan import *   #导入自定义表单验证模块
    #逻辑处理模块
    def special(request):
        request.session['k1'] = 123      #设置session
    
    
        a = request.session.session_key
        request.session.delete(a)
    
        return render(request, 'app1/index.html')
    复制代码

    request.session.set_expiry(value)设置session失效时间
      * 如果value是个整数,session会在value秒数后失效。
      * 如果value是个datatime或timedelta,session就会在这个时间后失效。
      * 如果value是0,用户关闭浏览器session就会失效。
      * 如果value是None,session会依赖全局session失效策略。


    2、缓存Session,保存在服务器内存

    复制代码
    a. 配置 settings.py
     
        SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎,表示保存在内存
        SESSION_CACHE_ALIAS = 'default'                            # 使用的缓存别名(default默认内存缓存,也可以是memcache,如果是memcache这里设置memcache缓存配置名称),此处别名依赖缓存的设置,见缓存章节
     
     
        SESSION_COOKIE_NAME = "sessionid"                        # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
        SESSION_COOKIE_PATH = "/"                                # Session的cookie保存的路径
        SESSION_COOKIE_DOMAIN = None                              # Session的cookie保存的域名
        SESSION_COOKIE_SECURE = False                             # 是否Https传输cookie
        SESSION_COOKIE_HTTPONLY = True                            # 是否Session的cookie只支持http传输
        SESSION_COOKIE_AGE = 1209600                              # Session的cookie失效日期(2周)
        SESSION_EXPIRE_AT_BROWSER_CLOSE = False                   # 是否关闭浏览器使得Session过期
        SESSION_SAVE_EVERY_REQUEST = False                        # 是否每次请求都保存Session,默认修改之后才保存
    复制代码

    使用同上

     


    3、文件Session,保存在文件里

    复制代码
    a. 配置 settings.py
     
        SESSION_ENGINE = 'django.contrib.sessions.backends.file'    # 引擎,文件保存引擎
        SESSION_FILE_PATH = None                                    # 缓存文件路径,如果为None,则使用tempfile模块获取一个临时地址tempfile.gettempdir()                                                            # 如:/var/folders/d3/j9tj0gz93dg06bmwxmhh6_xm0000gn/T
     
     
        SESSION_COOKIE_NAME = "sessionid"                          # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
        SESSION_COOKIE_PATH = "/"                                  # Session的cookie保存的路径
        SESSION_COOKIE_DOMAIN = None                                # Session的cookie保存的域名
        SESSION_COOKIE_SECURE = False                               # 是否Https传输cookie
        SESSION_COOKIE_HTTPONLY = True                              # 是否Session的cookie只支持http传输
        SESSION_COOKIE_AGE = 1209600                                # Session的cookie失效日期(2周)
        SESSION_EXPIRE_AT_BROWSER_CLOSE = False                     # 是否关闭浏览器使得Session过期
        SESSION_SAVE_EVERY_REQUEST = False                          # 是否每次请求都保存Session,默认修改之后才保存
    复制代码

    使用同上


    4、缓存+数据库Session,缓存和数据库都保存

    用户首次将Session保存到数据库,并保存一份到缓存,第二次到缓存里拿,如果缓存里没有,在到数据库拿又保存到缓存

    数据库用于做持久化,缓存用于提高效率
     
    a. 配置 settings.py
     
        SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'        # 引擎

    使用同上


    5、加密cookie Session,Session以cookie方式加密后保存在客户端

    a. 配置 settings.py
         
        SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'   # 引擎

    登录认证小列子

    复制代码
    def login(request):
        if request.method == "POST":
            username = request.POST.get("username")
            password = request.POST.get("password")
            if username == "zhangsan" and password == "123456":
                request.session["IS_LOGIN"] = True  #创建session
                return redirect("/app01/home/")
        return render(request,"app01/login.html")
    
    def home(request):
        islogin = request.session.get("IS_LOGIN",False)
        if islogin:#如果用户已登录
            return render(request,"app01/menus.html")
        else:
            return redirect("/app01/login/")
    
    def logout(request):#退出
        try:
            del request.session['IS_LOGIN']
        except KeyError:
            pass
        return redirect("/app01/login/")
    复制代码

    Session,保存在Redis

    首先安装Redis软件,然后安装第三方插件django-redis模块

    需要在全部配置里,将缓存配置和Session配置都要配置上

    复制代码
    #缓存配置
    # 自定义缓存key
    def default_key_func(key, key_prefix, version):
        return '%s:%s:%s' % (key_prefix, version, key)
    # 配置:
    CACHES = {
        'default': {
            'BACKEND': "django_redis.cache.RedisCache",     #配置文件引擎
            'LOCATION': "redis://127.0.0.1:6379",           #配置文件缓存路径
    
            'TIMEOUT': 300,                                 # 缓存超时时间(默认300秒,None表示永不过期,0表示立即过期)如果使用中没设置,这里启用
            'OPTIONS': {
                "CLIENT_CLASS": "django_redis.client.DefaultClient",
                'MAX_ENTRIES': 300,                         # 最大缓存个数(默认300)
                'CULL_FREQUENCY': 3,                        # 缓存到达最大个数之后,剔除缓存个数的比例,即:1/CULL_FREQUENCY(默认3,删除百分之3)
            },
            'KEY_PREFIX': 'jxiou',                          # 缓存key的前缀(默认空)
            'VERSION': 1,                                   # 缓存key的版本(默认1),设置后缓存key会是,KEY_PREFIX前缀加VERSION版本
            # 'KEY_FUNCTION': default_key_func              # 生成key的函数(默认函数会生成为:【前缀:版本:key】)
        }
    }
    
    #配置Session SESSION_ENGINE = 'django.contrib.sessions.backends.cache' # 引擎,表示保存在内存 SESSION_CACHE_ALIAS = 'default'         # 使用的缓存别名(default默认内存缓存,也可以是memcache,如果是memcache这里设置memcache缓存配置名称),此处别名依赖缓存的设置,见缓存章节 SESSION_COOKIE_NAME = "sessionid"       # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串 SESSION_COOKIE_PATH = "/"              # Session的cookie保存的路径 SESSION_COOKIE_DOMAIN = None          # Session的cookie保存的域名 SESSION_COOKIE_SECURE = False       # 是否Https传输cookie SESSION_COOKIE_HTTPONLY = True       # 是否Session的cookie只支持http传输 SESSION_COOKIE_AGE = 1209600         # Session的cookie失效日期(2周) SESSION_EXPIRE_AT_BROWSER_CLOSE = False   # 是否关闭浏览器使得Session过期 SESSION_SAVE_EVERY_REQUEST = False     # 是否每次请求都保存Session,默认修改之后才保存
    复制代码

    应用同上

  • 相关阅读:
    SpringCloud高可用和高并发
    时间重要性,我们需要如何利用极致
    Spring是什么 包括SpringBean SpringMVC SpringBoot SpringCloud
    Java 线程的基本使用
    JVM 内存模型
    Java 8 ArrayList 详解
    Java 8 HashMap 源码解析
    Docker 运行 MySQL,使用 docker-compose
    Spring Boot 主从读写分离
    Spring Boot 整合 MyBatis 实现乐观锁和悲观锁
  • 原文地址:https://www.cnblogs.com/meng-wei-zhi/p/8183126.html
Copyright © 2011-2022 走看看