java中的接口是类吗
245
2022-09-05
Django 状态保持3.5(django框架)
状态保持
startproject创建的项目默认启用在settings.py文件中
项INSTALLED_APPS列表中添加:'django.contrib.sessions',项MIDDLEWARE_CLASSES列表中添加:'django.contrib.sessions.middleware.SessionMiddleware',
禁用会话:删除上面指定的两个值,禁用会话将节省一些性能消耗
使用session
启用会话后,每个HttpRequest对象将具有一个session属性,它是一个类字典对象get(key, default=None):根据键获取会话的值clear():清除所有会话flush():删除当前的会话数据并删除会话的Cookiedel request.session['member_id']:删除会话
用户登录示例
操作效果如下图:
在views.py文件中创建视图
from django.shortcuts import render, redirectfrom django.core.urlresolvers import reversedef 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, urlurlpatterns = [ url(r'^', include('booktest.urls', namespace='main'))]应用url:from django.conf.urls import urlfrom . import viewsurlpatterns = [ 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
创建模板login.html
会话过期时间
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'))
存储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中的配置,增加如下项
SESSION_ENGINE = 'redis_sessions.session'SESSION_REDIS_HOST = 'localhost'SESSION_REDIS_PORT = 6379SESSION_REDIS_DB = 0SESSION_REDIS_PASSWORD = ''SESSION_REDIS_PREFIX = 'session'
管理redis的命令
启动:sudo redis-server /etc/redis/redis.conf停止:sudo redis-server stop重启:sudo redis-server restartredis-cli:使用客户端连接服务器keys *:查看所有的键get name:获取指定键的值del name:删除指定名称的键
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~