## **一、Session介绍**
1. `session`与`cookie`对比
1. `cookie`是在浏览器端保存键值对数据,而`session`是在服务器端保存键值对数据
2. 重要敏感的数据(银行卡账号,验证码,余额等),建议存储在服务器端,不能通过cookie保存到浏览器
3. `session`的使用依赖`cookie`
2. Django中`session`数据的保存
* 不同的用户使用各自不同的浏览器,可以认为:一个浏览器代表一个用户
* 【重要】表中一条记录,保存着一个浏览器(用户)所有的session键值对数据
* 【重要】`sessionid`是什么: 浏览器标识(用户标识),代表着一个用户,**通过`sessionid`可以找到该用户所有的session键值对数据**
## **二、Session使用**
1. 开启session功能【默认已经开启】
django封装了`session`模块,用来简化`session`数据操作。请参见`settings.py`配置文件中session配置:
~~~
INSTALLED_APPS = [
...
# 默认导入了django自带的session模块
'django.contrib.sessions',
]
MIDDLEWARE = [
...
# 开启session中间件
'django.contrib.sessions.middleware.SessionMiddleware',
]
~~~
2. **生成django项目默认的数据库表**
1. `session`数据默认保存在django项目的一张数据库表中(表名为:`django_session`)
2. **在保存session数据库前,需要先生成django项目默认的数据库表**
3. 如何生成: 打开终端,并进入到项目根目录下,再执行以下2个命令生成数据库表:
~~~
python manage.py makemigrations
python manage.py migrate
~~~
3. session数据操作
`request.session属性`:类型为`django.contrib.sessions.backends.db.SessionStore`
* 保存session数据(**键值对**)
~~~
request.session['键']=值
~~~
* 读取session数据
~~~
request.session.get('键', 默认值)
~~~
* 删除命令
~~~
# 删除一个sessoin键值对(注意:键不存在会报错 `KeyError`)
del request.session['键']
# 清除当前访问用户所有的session数据
request.session.flush() # 删除一条表记录
request.session.clear() # 清空字段中的session键值对数据
~~~
* 设置session数据有效时间;**如果不设置,默认过期时间为两周**
~~~
request.session.set_expiry(value)
~~~
* 如果value是一个整数,则 session数据 将在value秒没有活动后过期
* 如果value为0,则 session数据 将在用户**关闭浏览器时过期**
* 如果value为None,则 session数据 将在**2周后过期**
## **三、测试**
* 需求:
* 使用session保存 登录用户名 和 验证码:
* 访问`http://127.0.0.1:8000/set_session`界面时,保存session数据
* 访问`http://127.0.0.1:8000/get_session`界面时,读取session数据
* 实现参考
~~~
# url配置
url(r'^set_session$', views.set_session),
url(r'^get_session$', views.get_session),
# 视图函数
def set_session(request):
"""保存session键值对数据"""
request.session['user_id'] = 10
request.session['user_name'] = 'admin'
return HttpResponse('保存session成功')
def get_session(request):
"""读取session键值对数据"""
user_id = request.session.get('user_id')
user_name = request.session.get('user_name')
text = 'user_id = %s, user_name = %s' % (user_id, user_name)
return HttpResponse(text)
~~~
## 四、保存session到redis中
使用第三方包`django-redis`实现\*\*
1. 在虚拟环境下安装包
~~~
pip install django-redis==4.8.0
~~~
2. 修改`settings.py`文件,新增如下选项:
~~~
# django项目的缓存配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/1",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"PASSWORD": ""
}
}
}
# session数据缓存到Redis中
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"
~~~
3. 测试:**启动Redis服务器**,登录一次,再查看session是否有保存到 redis 1号数据库中
- 基础
- 输入输出
- 常量变量
- 常量
- 变量
- 数据类型
- 简单数据类型
- 整型
- 浮点型
- 复数
- 复杂数据类型
- 序列
- 通用操作
- 字符串
- 定义
- 方法
- 格式化
- eval
- range
- capitalize
- count
- 格式化
- list
- 定义
- 方法
- tuple
- 定义
- 特点
- 方法
- dict
- 定义
- set
- 定义
- 类型转换
- 函数
- 定义
- 参数
- 函数变量
- 多返回值
- 作用域
- 函数嵌套
- 匿名函数
- 面向对象
- 类
- 对象
- 封装
- 私有
- property
- 类属性和实例属性
- 实例方法、静态方法和类方法
- 继承
- 多态
- 接口
- 设计原则
- 开放/封闭原则
- 控制反转原则
- 接口隔离原则
- 单一职责原则
- 替换原则
- 魔法方法
- 构造方法
- 析构方法
- 静态方法
- doc
- call
- dict
- str
- 异常
- with
- 提高
- 深浅拷贝
- 闭包
- 装饰器
- 正则表达式
- 单个字符
- 多个字符
- 开头结尾
- 分组
- 高级语法
- 网络编程
- 多任务
- 线程
- 创建线程
- 主线程等待
- 共享全局变量
- 传递参数
- 进程
- 创建
- 进程间通信
- 协程
- 数据库
- SQL
- 安装
- 备份
- 查询
- 消除重复行
- 分组
- 字查询
- Python 中操作 MySQL
- 设计模式
- 简介
- 三大类
- 创建型
- 单例
- 常用模块
- 导入模块
- 系统内置
- os
- time
- math
- help
- logging
- 格式
- 输出到控制台
- 输出到文件
- 两个都输出
- 三方模块
- Tesseract
- redis
- 安装
- selenium
- Selenium
- PhantomJS
- Chromedriver
- turtle
- 五角星
- 正方体
- urllib3
- http请求
- Requests
- 基本使用
- 发送请求
- cookies
- 代理
- Django
- 框架介绍
- 项目搭建
- 项目配置
- 路由
- 项目urls.py
- 应用urls.py
- 控制器
- request
- response
- Cookie
- Session
- views
- Models
- 数据库
- ORM
- 配置和迁移
- 模型类
- 模型管理器
- 增删改
- 查
- 查询集
- Mysql日志
- 自定义模型管理器
- 中间件
- scrapy
- 工作原理
- 创建项目
- spider
- items
- pipeline
- settings
- logging
- 小例子
- 果壳网
- 人人网登陆
- 腾讯招聘
- 创建模块
- 网络爬虫
- 基础知识
- 爬虫的用途
- robots协议
- http和https
- 常见请求头
- 状态码
- 字符串
- requests
- 简介
- 发送请求
- response
- 小技巧
- 代理
- cookie和session
- Fiddler
- 数据提取
- 数据分类
- json
- 正则
- xpath
- lxml
- 自动化运维
- Shell
- 开发规范
- 注释
- 脚本执行
- 变量
- 表达式
- 测试语句
- 条件表达式
- 逻辑表达式
- 文件表达式
- 数值操作符
- 字符串比较
- 计算表达式
- 常见符号
- 重定向符号
- 管道符
- 其他符号
- 常见命令
- grep
- sed
- awk
- find
- 流程控制
- if