1.状态保持

  • http协议是无状态的:每次请求都是一次新的请求,不会记得之前通信的状态
  • 客户端与服务器端的一次通信,就是一次会话
  • 实现状态保持的方式:在客户端或服务器端存储与会话有关的数据
  • 存储方式包括cookie、session,会话一般指session对象
  • 使用cookie,所有数据存储在客户端,注意不要存储敏感信息
  • 推荐使用sesison方式,所有数据存储在服务器端,在客户端cookie中存储session_id
  • 状态保持的目的是在一段时间内跟踪请求者的状态,可以实现跨页面访问当前请求者的数据
  • 注意:不同的请求者之间不会共享这个数据,与请求者一一对应

2.session

启用session

  • 使用django-admin startproject创建的项目默认启用
  • 在settings.py文件中
项INSTALLED_APPS列表中添加:
'django.contrib.sessions',

项MIDDLEWARE_CLASSES列表中添加:
'django.contrib.sessions.middleware.SessionMiddleware',
  • 禁用会话:删除上面指定的两个值,禁用会话将节省一些性能消耗

使用session

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

3 .用户登录示例

  • 在views.py文件中创建视图
from django.shortcuts import render, redirect
from django.core.urlresolvers import reverse def index(request):
uname = request.session.get('uname')
return render(request, 'booktest/index.html', {'uname': uname}) def login(request):
return render(request, 'booktest/login.html') def login_handle(request):
request.session['uname'] = request.POST['uname']
return redirect(reverse('main:index')) def logout(request):
# request.session['uname'] = None
# del request.session['uname']
# request.session.clear()
request.session.flush()
return redirect(reverse('main:index'))
  • 配置url
主url:
from django.conf.urls import include, url
urlpatterns = [
url(r'^', include('booktest.urls', namespace='main'))
]
应用url:
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^$', views.index, name='index'),
url(r'login/$', views.login, name='login'),
url(r'login_handle/$', views.login_handle, name='login_handle'),
url(r'logout/$', views.logout, name='logout')
]
  • 创建模板index.html
<!DOCTYPE html>
<html>
<head>
<title>首页</title>
</head>
<body>
你好:{{uname}}
<hr/>
<a href="{%url 'main:login'%}">登录</a>
<hr/>
<a href="{%url 'main:logout'%}">退出</a>
</body>
</html>
  • 创建模板login.html
<!DOCTYPE html>
<html>
<head>
<title>登录</title>
</head>
<body>
<form method="post" action="/login_handle/">
<input type="text" name="uname"/>
<input type="submit" value="登录"/>
</form>
</body>
</html>

# 通过用户登陆练习
# session练习 def session1(request):
uname = request.session.get('myname', '未登录')
context = {'uname': uname}
return render(request, 'booktest/session1.html', context) def session2(request):
context = {}
return render(request, 'booktest/session2.html', context) def session2_handle(request):
uname = request.POST['uname']
request.session['myname'] = uname
return redirect('/booktest/session1') def session3(request):
# 删除session
# request.session.flush()
del request.session['myname']
return redirect('/booktest/session1')

View

4.会话过期时间

  • set_expiry(value):设置会话的超时时间
  • 如果没有指定,则两个星期后过期
  • 如果value是一个整数,会话将在values秒没有活动后过期
  • 若果value是一个imedelta对象,会话将在当前时间加上这个指定的日期/时间过期
  • 如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期
  • 如果value为None,那么会话永不过期
  • 修改视图中login_handle函数,查看效果
def login_handle(request):
request.session['uname'] = request.POST['uname']
# request.session.set_expiry()
# request.session.set_expiry(timedelta(days=))
# request.session.set_expiry()
# request.session.set_expiry(None)
return redirect(reverse('main:index'))

5

5. 存储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'
  • session存放位置

6.使用Redis缓存session

  • 会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储
  • 安装包
pip install django-redis-sessions
  • 修改settings中的配置,增加如下项
SESSION_ENGINE = 'redis_sessions.session'
SESSION_REDIS_HOST = 'localhost'
SESSION_REDIS_PORT =
SESSION_REDIS_DB =
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:删除指定名称的键

session依赖于cookies

7.session总结

最新文章

  1. 第14章 Linux启动管理(1)_系统运行级别
  2. 测试EF6.1.3和OrmLite性能
  3. ubuntu 下安装redis 以及php扩展
  4. 智能生活 科技无限 CTO VOICE 第二期 智能硬件创新创业专场演讲嘉宾招募
  5. VMware 安装CentOS
  6. oracle删除数据库中的所有数据的拼接语句
  7. 破解网络投票IP限制、验证码限制、COokie限制、Seesion限制的方法!(转)
  8. 转:SQL Case when 的使用方法
  9. HDU 5170 GTY&#39;s math problem
  10. 关于js中单双引号以及转义符的理解
  11. 浅谈Trie树(字典树)
  12. Hdu 3001 Travelling 状态DP
  13. Servlet接口UML图
  14. Perl的time、localtime和gmtime函数
  15. 《从Paxos到Zookeeper:分布式一致性原理与实践》第一章读书笔记
  16. 模拟器 Unable to execute simctl install Error 117
  17. python pickle模块的使用/将python数据对象序列化保存到文件中
  18. Hisat2 bowtie2比对结果解读(Hisat2 Alignment summary)
  19. [jquery] 遮罩弹窗,点击遮罩弹窗自动隐藏
  20. jquery插件Loadmask

热门文章

  1. Storm里面fieldsGrouping和Field的概念详解
  2. 用C++/CLI搭建C++和C#之间的桥梁
  3. C#对话框-打开和保存对话框(转)
  4. postman传递参数的问题
  5. bzoj4622 [NOI 2003] 智破连环阵
  6. expect脚本中,变量的写法
  7. 2018. 2.4 Java中集合嵌套集合的练习
  8. 2017.12.20 Java中的 IO/XML学习总结 File类详细
  9. mac 远程桌面提示: 证书或相关链无效
  10. PHP 的那些错误总结