十一 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,默认修改之后才保存

应用同上

原文地址:https://www.cnblogs.com/meng-wei-zhi/p/8183126.html

时间: 2024-10-01 19:44:10

十一 Django框架,Session的相关文章

第十一章 Django框架学习——Cookie和session

第十一章 Django框架学习--Cookie和session 一.Cookie简介 二.装饰器版登录校验 三.session简介 四.如何在CBV中使用装饰器 一.Cookie简介 什么是Cookie(what): Cookie具体指的是一段小信息,它是服务器发送出来存储在浏览器上的一组组键值对,下次访问服务器时浏览器会自动携带这些键值对,以便服务器提取有用信息. Cookie的原理:由服务器产生内容,浏览器收到请求后保存在本地:当浏览器再次访问时,浏览器会自动带上Cookie,这样服务器就能

第三百二十一节,Django框架,发送邮件

第三百二十一节,Django框架,发送邮件 全局配置settings.py EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' #发送邮件引擎 EMAIL_USE_TLS = False #是否以https方式 EMAIL_HOST = 'smtp.163.com' #邮件smtp服务器 EMAIL_PORT = 25 #端口 EMAIL_HOST_USER = '[email protected]' #发件人 EMAIL_

Django 框架篇(六): Cookie 与 Session

Cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不会直接影响后面的请求响应情况. 一句有意思的话来描述就是人生只如初见,对服务器来说,每次的请求都是全新的. 状态可以理解为客户端和服务器在某次会话中产生的数据,那无状态的就以为这些数据不会被保留.会话中产生的数据又是我们需要保存的,也就是说要"保持状态".因此Cookie就是在这样一个场景

Django框架之session

Session介绍: 在计算机中,尤其是在网络应用中,称为“会话控制”.Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去.当用户请求来自应用程序的 Web 页时,如果该用户还没有会话,则 Web 服务器将自动创建一个 Session 对象.当会话过期或被放弃后,服务器将终止该会话.Session 对象最常见的一个用法就是存储用户的首选项. Session作用:

框架----Django框架知识点整理

一.cbv 1 cbv(class-base-view) 基于类的视图 2 fbv(func-base-view) 基于函数的视图 a.基本演示 1 urlpatterns = [ 2 3 url(r'^login.html$', views.Login.as_view()), 4 ] urls.py 1 from django.views import View 2 3 class Login(View): 4 """ 5 get 查 6 post 创建 7 put 更新

Django框架<一>

Django框架 Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. 一.django的安装实现和目录介绍 1.django实现流程 django #安装: pip3 install django 添加环境变量 #1 创建project django-admin startproject mysite ---mysite ---settings.p

Django框架

Django框架全面讲解 Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. 本文将带大家全面了解Django框架,笔者使用的版本为1.10. 1 Django流程介绍 2 Django 基本配置 一.创建django程序 终端命令:django-admin startproject sitename  (在当前目录下创建一个Django程序) I

使用Django框架实现游戏网站搭建

完整工程链接点击打开链接 上一篇中我们使用了Javascript和Html5实现了弹球游戏,而在本文中我们希望以其为基础实现游戏网站,能够实现用户的注册登录,游戏成绩记录,排名显示,微博分享等功能. 最终效果: 2. 网站的搭建和服务器的搭建 2.1 网站整体构成 网站的搭建我使用django框架. 2.1.1 数据库设计 User: Field Type Null Key Default Description Name Varchar(50) No Primary 用户ID Password

Django框架开发中避免表单重复提交

Form表单做为web2.0时代的重要角色,也是我们与web网站进行数据交互的重要渠道,但是大家在web网站开发过程中,都会遇到一个问题,那就是如何避免表单重复提交,我们可不确定用户可在提交了一个表单后,是否有足够的耐心等待我们的程序加载完成,如果此时用户不耐烦的在前台重复刷新页面,那么就会造成数据重复提交.信息不准确,因此我们在程序设计时一定要规避这样的问题,接下来介绍一下在Django框架开发中如何避免此问题. 首先说明一下Http协议中两种非常常见的方法GET和POST. 1.GET方法往