django-web开发框架-状态保持session

状态保持

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

启用session

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

  2. 'django.contrib.sessions',

  3.  
  4. 项MIDDLEWARE_CLASSES列表中添加:

  5. 'django.contrib.sessions.middleware.SessionMiddleware',

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

使用session

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

用户登录示例

  • 操作效果如下图:

登录演示

  • 在views.py文件中创建视图
 
  1. from django.shortcuts import render, redirect

  2. from django.core.urlresolvers import reverse

  3.  
  4. def index(request):

  5. uname = request.session.get('uname')

  6. return render(request, 'booktest/index.html', {'uname': uname})

  7.  
  8. def login(request):

  9. return render(request, 'booktest/login.html')

  10.  
  11. def login_handle(request):

  12. request.session['uname'] = request.POST['uname']

  13. return redirect(reverse('main:index'))

  14.  
  15. def logout(request):

  16. # request.session['uname'] = None

  17. # del request.session['uname']

  18. # request.session.clear()

  19. request.session.flush()

  20. return redirect(reverse('main:index'))

  • 配置url
 
  1. 主url:

  2. from django.conf.urls import include, url

  3. urlpatterns = [

  4. url(r'^', include('booktest.urls', namespace='main'))

  5. ]

  6.  
  7. 应用url:

  8. from django.conf.urls import url

  9. from . import views

  10. urlpatterns = [

  11. url(r'^$', views.index, name='index'),

  12. url(r'login/$', views.login, name='login'),

  13. url(r'login_handle/$', views.login_handle, name='login_handle'),

  14. url(r'logout/$', views.logout, name='logout')

  15. ]

  • 创建模板index.html
 
  1. <!DOCTYPE html>

  2. <html>

  3. <head>

  4. <title>首页</title>

  5. </head>

  6. <body>

  7. 你好:{{uname}}

  8. <hr/>

  9. <a href="{%url 'main:login'%}">登录</a>

  10. <hr/>

  11. <a href="{%url 'main:logout'%}">退出</a>

  12. </body>

  13. </html>

  • 创建模板login.html
 
  1. <!DOCTYPE html>

  2. <html>

  3. <head>

  4. <title>登录</title>

  5. </head>

  6. <body>

  7. <form method="post" action="/login_handle/">

  8. <input type="text" name="uname"/>

  9. <input type="submit" value="登录"/>

  10. </form>

  11. </body>

  12. </html>

 

1、views

 

2、urls

 

3、HTML

 

 

 

会话过期时间

http://k.sina.com.cn/article_6792616786_194df1b5200100vjqp.html
http://k.sina.com.cn/article_6792616786_194df1b5200100vva1.html
http://k.sina.com.cn/article_6792616786_194df1b5200100vz3s.html
http://k.sina.com.cn/article_6792616786_194df1b5200100vz46.html
http://k.sina.com.cn/article_6792616786_194df1b5200100w0zz.html
http://k.sina.com.cn/article_6792616786_194df1b5200100w10a.html
http://k.sina.com.cn/article_6792616786_194df1b5200100w130.html
http://k.sina.com.cn/article_6407046367_17de3c4df00100e0kp.html
http://k.sina.com.cn/article_6407046367_17de3c4df00100e1gv.html
http://k.sina.com.cn/article_6407046367_17de3c4df00100e1gx.html

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

  2. request.session['uname'] = request.POST['uname']

  3. # request.session.set_expiry(10)

  4. # request.session.set_expiry(timedelta(days=5))

  5. # request.session.set_expiry(0)

  6. # request.session.set_expiry(None)

  7. return redirect(reverse('main:index'))

 

base64解码:

http://tool.oschina.net/encrypt?type=3

 

存储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

  • 会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储
  • 安装包
pip install django-redis-sessions

  • 修改settings中的配置,增加如下项
 
  1. SESSION_ENGINE = 'redis_sessions.session'

  2. SESSION_REDIS_HOST = 'localhost'

  3. SESSION_REDIS_PORT = 6379

  4. SESSION_REDIS_DB = 0

  5. SESSION_REDIS_PASSWORD = ''

  6. SESSION_REDIS_PREFIX = 'session'

  •  
  • 管理redis的命令
 
  1. 启动:sudo redis-server /etc/redis/redis.conf

  2. 停止:sudo redis-server stop

  3. 重启:sudo redis-server restart

  4. redis-cli:使用客户端连接服务器

  5. keys *:查看所有的键

  6. get name:获取指定键的值

  7. del name:删除指定名称的键

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值