-- 状态保持

# http协议是
无状态的;不记录你之前干过什么;
# 实现状态保持的方式:在客户端或服务器端存储与会话有关的数据;
# 使用cookie,所有数据存储在客户端,注意不要存储敏感信息
# 推荐使用sesison方式,所有数据存储在服务器端,在客户端cookie中存储session_id
# 状态保持的目
的是在一段时间内跟踪请求者的状态,可以实现跨页面访问当前请求者的数据

-- SESSION

-- 启用(默认启用)

# 项INSTALLED_APPS列表中添加:
# 'django.contrib.sessions',
# 项MIDDLEWARE_CLASSES列表中添加:
# 'django.contrib.sessions.middleware.SessionMiddleware',
# 禁用会话:删除上面指定的两个值,禁用会话将节省一些性能消耗;(代码注释)

-- 使用

# 启用会话后,每个HttpRequest对象将具有一个session属性,它是一个类字典对象
# get(key, default=None):根据键获取会话的值
# clear():清除所有会话
# flush():删除当前的会话数据并删除会话的Cookie
# del request.session['member_id']:删除会话

-- 示例

-- views.py

# # 通过用户登录练习session
# def session1(request):
# # 通过get()获取,就算没有值也不会报错,会弹出默认none;
# # 也可以自己传入一个参数来改写默认值;
# # 如果通过字典方式,就会报错;
# uname = request.session.get('myname', '未登录')
# context = {'uname':uname}
# return render(request, 'booktest/session1.html', context)
# def session2(request):
# return render(request, 'booktest/session2.html')
# def session2_handle(request):
# # 保存对session页面的表单中提交的内容,到数据库中的session表;
# # 并重定向至session1页面;
# uname = request.POST['uname']
# request.session['myname'] = uname
# return redirect('/booktest/session1/')
# def session3(request):
# # 删除session
# del request.session['myname']
# # 重定向至session1页面;
# return redirect('/booktest/session1/')

-- 配置url

# url(r'^session1/$', views.session1),
# url(r'^session2/$', views.session2),
# url(r'^session2_handle/$', views.session2_handle),
# url(r'^session3/$', views.session3),

-- 创建session1.html

# <body>
#  你好:`uname`
#  <br>
#  <a href="/booktest/session2">登录</a>
#  <br>
#  <a href="/booktest/session3">退出</a>
# </body>

-- 创建session2.html

# <body>
# <form method='post' actions="/booktest/session2_handle">
# <input type="text" name="uname">
# <input type="submit" name="登录">
# </form>
# </body>

# -- 通过session存值

# -- 通过session取值

# -- 删除session值


-- 会话过期时间

-- set_expiry(value):

-- 设置会话的超时时间

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

# 如果value是一个整数,会话将在values秒没有活动后过期
# 若果value是一个imedelta对象,会话将在当前时间加上这个指定的日期/时间过期
# 如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期
# 如果value为None,那么会话永不过期
# def session2_handle(request):
# # 保存对session页面的表单中提交的内容,到数据库中的session表;
# # 并重定向至session1页面;
# uname = request.POST['uname']
# request.session['myname'] = uname
#     # request.session.set_expiry(10)
#     # request.session.set_expiry(timedelta(days=5))
#     # request.session.set_expiry(0)
#     # request.session.set_expiry(None)
# return redirect('/booktest/session1/')


-- 存储session

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

-- 基于数据库的会话:这是django默认的会话存储方式,需要添加django.contrib.sessions到的INSTALLED_APPS设置中,

运行manage.py migrate在数据库中安装会话表,可显示指定为;

# SESSION_ENGINE='django.contrib.sessions.backends.db'

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

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

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

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



-- 使用Redis缓存session

# session依赖于cookie?

-- 安装包

# pip install django-redis-sessions

-- 修改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'

-- 管理redis的命令

# 启动:sudo redis-server /etc/redis/redis.conf
# 停止:sudo redis-server stop
# 重启:sudo redis-server restart
# redis-cli:使用客户端连接服务器
# keys *:查看所有的键
# get name:获取指定键的值
# del name:删除指定名称的键