zoukankan      html  css  js  c++  java
  • 6.Django session

    session

     1.概述

    cookie和session的区别

    Cookie是保存在用户浏览器端的键值对,Session是保存在服务器端的键值对;Cookie做用户验证的时,敏感信息不适合放在Cookie中,别人可以分析存放在本地的Cookie并进行Cookie欺骗,考虑到安全应当使用Session;用户验证时两者要结合使用,Session可保存到文件,内存,数据库任意地方

     2.session操作

    (1)获取

    # 获取Session中数据
    request.session['k1']
    request.session.get('k1', None)

    (2)生成

    # 生成Session中数据
    request.session['k1'] = 123
    request.session.setdefault('k1', 123)  # 存在则不设置

    (3)删除

    # 删除Session中某条数据
    del request.session['k1']
     
    # 删除当前用户的所有Session数据
    request.session.delete("session_key")
    request.session.clear()         #注销时可用

    (4)键值对

    # 所有 键、值、键值对
    request.session.keys()
    request.session.values()
    request.session.items()
    request.session.iterkeys()
    request.session.itervalues()
    request.session.iteritems()

    (5)超时时间

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

    (6)others

    # 用户session的随机字符串
    request.session.session_key
     
    # 将所有Session失效日期小于当前日期的数据删除
    request.session.clear_expired()
     
    # 检查 用户session的随机字符串 在数据库中是否 一般用不到
    request.session.exists("session_key")

    3.数据库存储session

    Django默认支持Session,并且默认是将Session数据存储在数据库中,即:django_session表中
    
    配置settings.py
    SESSION_ENGINE = 'django.contrib.sessions.backends.db'  # 引擎(默认)
    
    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,默认修改之后才保存(默认)
                                        #  设置Ture后,每次点击页面,时间更新

    4.缓存存储session

    配置settings.py
    
    SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎
    SESSION_CACHE_ALIAS = 'default'  # 使用的缓存别名(默认内存缓存,也可以是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,默认修改之后才保存

    可以设置为Memcache缓存,默认不支持redis(可以使用网上插件)

    配置settings.py
    
    SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎
    SESSION_CACHE_ALIAS = 'db'  # 使用的缓存别名,此处别名依赖缓存的设置
    
    CACHES = {
        'default': {
            'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
            'LOCATION': [
                '172.19.26.240:11211',
                '172.19.26.242:11211',
            ]
        },
        'db': {
            'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
            'LOCATION': [
                '172.19.26.240:11211',
                '172.19.26.242:11211',
            ]
        }
    }
    Memcache缓存

    5.文件存储session

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

    6.缓存加数据库session

    数据库用于做持久化,缓存用于提高效率,先去缓存中取数据,缓存没有再去数据库中取,然后在缓存中存一份
    
    配置settings.py
    
    SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'  # 引擎

    7.加密cookie session

    数据都存在于客户端
    配置settings.py
    
    SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'  # 引擎

    用户登录

     login.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        <form action="/login/" method="post">
            <input type="text" name="user" />
            <input type="text" name="pwd" />
            <input type="checkbox" name="session" value="1"/>     //设置超时时间的
            <input type="submit" value="提交" />
        </form>
    </body>
    </html>

    index.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        {{ request.session.username }}    //获取登录的用户名
    </body>
    </html>

    views.py

    from  django.shortcuts import render,HttpResponse,redirect
    
    def login(request):
        if request.method == 'GET':
            return render(request ,'login.html')
        elif request.method == 'POST':
            user = request.POST.get('user')
            pwd = request.POST.get('pwd')
            if user == 'root' and pwd == "123":
                # 生成随机字符串
                # 写到用户浏览器Cookie
                # 保存到Session中
                #  在随机字符串对应的字典中设置相关内容...
                request.session['username'] = user
                request.session['if_login'] = True  # 可不加 直接判断username也可以
                if request.POST.get('session') == '1':  # 单独设置超时时间,当前session生效,不影响全局
                    request.session.set_expiry(10)  # 10秒
                return redirect('/index/')
            else:
                return redirect('/login/')
    
    def index(request):
        # 获取当前用户的随机字符串
        # 根据随机字符串获取对应信息
        if request.session.get('if_login'):
            return render(request, 'index.html')
        else:
            return redirect('/login/')

    登录成功后,浏览器可以看到有一个sessionid

     
     
     
  • 相关阅读:
    根据前序遍历和中序遍历重建二叉树
    Java内部类
    Java浅克隆和深度克隆
    【leetcode】1354. Construct Target Array With Multiple Sums
    【leetcode】1352. Product of the Last K Numbers
    【leetcode】1351. Count Negative Numbers in a Sorted Matrix
    【leetcode】1342. Number of Steps to Reduce a Number to Zero
    【leetcode】1343. Number of Sub-arrays of Size K and Average Greater than or Equal to Threshold
    【leetcode】1344. Angle Between Hands of a Clock
    【leetcode】1346. Check If N and Its Double Exist
  • 原文地址:https://www.cnblogs.com/gaidy/p/12084909.html
Copyright © 2011-2022 走看看