蒋振飞的博客 - Django框架07:状态保持   
正在加载蒋振飞的博客...
V3.0
蒋振飞的博客

Django框架07:状态保持

发布时间: 2018年07月14日 发布人: 蒋振飞 热度: 428 ℃ 评论数: 0

1.状态保持

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

2.启用session

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

'django.contrib.sessions',

        MIDDLEWARE_CLASSES列表中添加:

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

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

3.使用session

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

4.登录演示

    1) 创建视图

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'))

    2) 配置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')
]

   3) 创建模板

<!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>

    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(10)
    # request.session.set_expiry(timedelta(days=5))
    # request.session.set_expiry(0)
    # request.session.set_expiry(None)
    return redirect(reverse('main:index'))

    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'

     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 = 6379
SESSION_REDIS_DB = 0
SESSION_REDIS_PASSWORD = ''
SESSION_REDIS_PREFIX = 'session'

    7) 管理redis的命令
        启动:

sudo redis-server /etc/redis/redis.conf

        停止:

sudo redis-server stop

        重启:

sudo redis-server restart

        redis-cli:使用客户端连接服务器。
        keys *:查看所有的键。
        get name:获取指定键的值。
        del name:删除指定名称的。

打赏 蒋振飞

取消

感谢您的支持,我会继续努力的!

扫码支持
一分也是爱     一块不嫌多

点击 支付宝 或 微信 打赏蒋振飞

打开支付宝扫一扫,即可进行扫码打赏哦

评论列表