django session

一、启用、禁用session

1、启用session(使用django-admin startproject创建的项目默认启用)

     在settings.py文件中

INSTALLED_APPS列表中添加: 'django.contrib.sessions', 

MIDDLEWARE_CLASSES列表中添加: 'django.contrib.sessions.middleware.SessionMiddleware',

2、禁用会话:删除上面指定的两个值,禁用会话将节省一些性能消耗

二、使用session

启用会话后,每个HttpRequest对象将具有一个session属性,它是一个类字典对象

get(key, default=None):根据键获取会话的值

clear():清除所有会话

flush():删除当前的会话数据并删除会话的Cookie

del request.session['member_id']:删除会话

示例:

uname = request.session.get('uname')
request.session['uname'] = None
del request.session['uname']
request.session.clear()
request.session.flush()

三、会话过期时间

set_expiry(value):设置会话的超时时间

如果没有指定,则两个星期后过期

如果value是一个整数,会话将在values秒没有活动后过期

若果value是一个timedelta对象,会话将在当前时间加上这个指定的日期/时间过期

如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期

如果value为None,那么会话永不过期

示例:

def login_handle(request): 
    request.session['uname'] = request.POST['uname'] 
    # request.session.set_expiry(10) 
    #  request.session.set_expiry(timedelta(days=5)) 
    #  request.session.set_expiry(0) 
    #  request.session.set_expiry(None) 
    return HttpResponse('ok')

四、存储session

使用存储会话的方式,可以使用settings.py的SESSION_ENGINE项指定

1、基于数据库的会话:这是django默认的会话存储方式

    • 添加django.contrib.sessions到的INSTALLED_APPS设置中,
    • 运行manage.py migrate在数据库中安装会话表,
    • 可显示指定为 SESSION_ENGINE='django.contrib.sessions.backends.db'

2、基于缓存的会话:只存在本地内在中,如果丢失则不能找回,比数据库的方式读写更快

SESSION_ENGINE='django.contrib.sessions.backends.cache'

3、可以将缓存和数据库同时使用:优先从本地缓存中获取,如果没有则从数据库中获取

SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

使用Redis缓存session

会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储

1、安装包 pip install django-redis-sessions

2、修改settings中的配置,增加如下项

SESSION_ENGINE = 'redis_sessions.session'
SESSION_REDIS_HOST = 'localhost'
SESSION_REDIS_PORT = 6379
SESSION_REDIS_DB = 0
SESSION_REDIS_PASSWORD = ''
SESSION_REDIS_PREFIX = 'session'

 

posted @ 2018-08-31 11:27  逐梦客!  阅读(108)  评论(0)    收藏  举报