Session

cookie:保存在客户端浏览器上的键值对
session:保存在服务器端的数据
      保持会话

def index(req):
v = req.session.get('username')
if v:
return render(req, './App4/index.html', {'user': v})
else:
return render(req, './App4/login.html', {'msg': ''}) def login(request):
if request.method == 'GET':
return render(request, './App4/login.html', {'msg': ''})
else:
u = request.POST.get('username') # 生成随机串{'username':'lhh'}
p = request.POST.get('password') # 通过session并保存
key = {'username': u, 'password': p}
obj = models.User.objects.filter(**key).first()
if obj:
request.session['username'] = u
request.session['password'] = p
return redirect('./index/')
else:
return render(request, './App4/login.html', {'msg': '用户名或密码错误'})
#设置
def login(request):
if request.method == 'GET':
return render(request, 'App5/login.html')
else:
user = request.POST.get('uname')
pwd = request.POST.get('pwd')
gender = request.POST.get('gender')
week = request.POST.get('week')
if gender == '1':
obj = models.Boy.objects.filter(**{'name': user, 'passwd': pwd}).first()
else:
obj = models.Girl.objects.filter(**{'name': user, 'passwd': pwd}).first()
if obj:
user_info = {'user_id': obj.id, 'gender': gender, 'uname': user, 'nickname': obj.nickname}
request.session['user_info'] = user_info
return redirect('App5/index.html')
#使用
def index(request):
v = request.session.get('user_info')
if not v:
return redirect('./App5/login.html')
else:
gender = v.get('gender')
name = v.get('nickname')
if gender == '1':
user_list = models.Girl.objects.all()
else:
user_list = models.Boy.objects.all()
return render(request, './App5/index.html', {'userList': user_list, 'name': name})
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>index</title>
</head>
<body>
<!--render将request也会传过来,通过request也可以调用session-->
<h2>当前用户:{{ request.session.user_info.nickname }}</h2>
<ul>
{% for i in userList %}
<li> {{ i.nickname }}</li>
{% endfor %}
</ul> </body>
</html>

session相关操作:

#与字典相似
request.session.keys()
request.session.values()
request.session.items() request.session.session_key #用户的随机字符串
request.session.delete('session_key') #删除当前用户的session
request.session.exists('session_key') #检查当前用户的随机字符串是否在数据库中
request.session.flush() #删除所有session request.session.clear_expired() #清除过期的session
request.session.set_expiry(value) #设置超时时间,默认两周,单位(秒)

session相关设置:

参数 意义 默认
SESSION_COOKIE_NAME 保存在浏览器中的key ‘sessionid’
SESSION_COOKIE_PATH session的cookie路径 “\”
SESSION_COOKIE_DOMAIN session的cookie保存的域名 None
SESSION_COOKIE_SECURE 是否使用Https传输cookie False
SESSION_COOKIE_HTTPONLY 是否仅使用Http传输cookie True
SESSION_EXPIRE_AT_BROWSER_CLOSE 字面意思
SESSION_SAVE_EVERY_REQUEST 是否每次刷新浏览器都更新默认时间 False

上述参数均可在setting文件中更改设置

						setting.py
SESSION_COOKIE_NAME = 'sessionid'
SESSION_COOKIE_PATH = '/'
SESSION_COOKIE_DOMAIN = None
SESSION_COOKIE_SECURE = False
SESSION_COOKIE_HTTPONLY = True
SESSION_EXPIRE_AT_BROWSER_CLOSE = False
SESSION_SAVE_EVERY_REQUEST = False
#默认
SESSION_ENGINE='django.contrib.sessions.backends.db' #session引擎设置 表示将session_key放入数据库 SESSION_ENGINE= 'django.contrib.sessions.backends.file'#将session存入文件
SESSION_FILE_PATH='\XX\XX'
# SESSION_ENGINE='django.contrib.sessions.backends.cache'#放缓存 SESSION_ENGINE='django.contrib.sessions.backends.cache_db'#缓存+数据库,缓存找不着就找数据库

Django基础笔记5(Session)的更多相关文章

  1. Django基础cookie和session

    Django基础cookie和session 1.会话跟踪 ​ 什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如给10086打个电话,你就是客户端, ...

  2. Django 基础笔记补充

    1.目录文件 django-admin.py startproject mydj cd mydj python manage.py startapp myapp   后生成目录: mydj/ ├── ...

  3. Django基础笔记

    1.准备工作 .虚拟环境设置 python3 pip install virtualenv python -m venv env(虚拟环境文件名) env\Scripts\activate pip i ...

  4. python笔记-19 javascript补充、web框架、django基础

    一.JavaScript的补充 1 正则表达式 1.1 test的使用 test 测试是否符合条件 返回true or false 1.2 exec的使用 exec 从字符串中截取匹配的字符 1.3 ...

  5. Django学习笔记(基础篇)

    Django学习笔记(基础篇):http://www.cnblogs.com/wupeiqi/articles/5237704.html

  6. {Django基础八之cookie和session}一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session

    Django基础八之cookie和session 本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 xxx 七 ...

  7. 【笔记】Django基础(一)

    ---恢复内容开始--- [笔记]Django基础(一) oldboy Django  一 关于Python框架的本质 1. HTTP协议消息的格式: 请求(request) 请求方法 路径 HTTP ...

  8. day 62.3 Django基础八之cookie和session

    Django基础八之cookie和session   本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 xxx ...

  9. day 73 Django基础八之cookie和session

      Django基础八之cookie和session   本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 x ...

  10. Django基础六之cookie和session

    Django基础六之cookie和session 目录 Django基础六之cookie和session 1. cookie和session介绍 1.1 cookie 简介 1.2 cookie的缺陷 ...

随机推荐

  1. 【ProxySQL】ProxySQL Cluster的搭建

    文章转载自:https://blog.51cto.com/l0vesql/2104643 背景 早期的ProxySQL若需要做高可用,需要搭建两个实例,进行冗余.但两个ProxySQL实例之间的数据并 ...

  2. proxysql cluster 的搭建

    文章转载自:https://blog.51cto.com/lee90/2298804 官方文档: https://proxysql.com/blog/proxysql-cluster 环境架构 在一主 ...

  3. Traefik 2.0 实现自动化 HTTPS

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247484457&idx=1&sn=35112e98 ...

  4. 跟我学Python图像处理丨带你掌握傅里叶变换原理及实现

    摘要:傅里叶变换主要是将时间域上的信号转变为频率域上的信号,用来进行图像除噪.图像增强等处理. 本文分享自华为云社区<[Python图像处理] 二十二.Python图像傅里叶变换原理及实现> ...

  5. PHP全栈开发(八):CSS Ⅶ 表格 style

    表格默认是没有边框的,因此,我们在设置表格格式的时候,首先要设置的是表格边框的样式,也就是 table{ border-style:solid; } 设置完表格表格的样式之后,可以设置表格边框的粗细程 ...

  6. ExcelHelper ->NPOI插件

    调用: var ms = ExcelHelper.PrintInvoiceToExcel("观看时长", headline, items, (row, item) => { ...

  7. [Android开发学iOS系列] ViewController

    iOS ViewController 写UIKit的代码, ViewController是离不开的. 本文试图讲讲它的基本知识, 不是很深入且有点杂乱, 供初级选手和跨技术栈同学参考. What is ...

  8. VLQ & Base64 VLQ 编码方式的原理及代码实现

    目录 VLQ Base64 VLQ VLQ VLQ (Variable-length quantity)是一种通用的,使用任意位数的二进制来表示一个任意大的数字的一种编码方式. 编码实现: ** 对数 ...

  9. 22.-CSRF攻击

    一.CSRF-跨站伪造请求攻击 某些恶意网站上包含链接.表单按钮或者JavaScript,它们会利用登录过的用户在浏览器中的认证信息视图在你的网站上完成某些操作 这就是跨站请求伪造(CSRF,即Cro ...

  10. zk系列二:zookeeper实战之分布式统一配置获取

    前面介绍了zk的一些基础知识,这篇文章主要介绍下如何在java环境下获取zk的配置信息:主要基于zk的监听器以及回调函数通过响应式编程的思想将核心代码糅合成一个工具类,几乎做到了拿来即用: 在分布式集 ...