一、会话技术cookie
- 概述
客户端的
所有数据都在客户端
存储方式key-value
cookie浏览器自动携带本站数据
cookie支持过期时间
- 设置cookie
response.set_cookie(key, value)
- 获取cookie
request.cookies.get(key)
- 删除cookie
response.delete_cookie(key)
二、会话技术session
- 概述
服务端的会话技术
所有数据都在服务器
存储在内存中【未做持久化处理】
session 是依赖于cookie
如果要使用session,要设置秘钥
app.config['SECRET_KEY'] = '13124323342'
- 设置session
session[key] = value
- 获取session
session.get(key)
- 删除session
session.pop(key)
response.delete_cookie('session')
三、flask-session插件
- 概述
- flask中session默认是内存(django默认持久化存储是在数据库)
- flask-session 可以实现session持久化存储
- 安装
pip install flask-session
- 初始化
__init__.py
# 必选
app.config['SESSION_TYPE'] = 'redis' # session持久化策略 redis
# 可选(客户端显示key)
app.config['SEESION_COOKIE_NAME'] = 'sessionid_uu'
# 可选(过期时间)
app.config['PERMANENT_SESSION_LIFETIME'] = 60
# 方式一
Session(app) #实例化Session对象
# 方式二
sess = Session()
sess.init_app(app)
- 使用
和系统session使用一模一样,即只要配送需要插件,源代码无需要做任何修改;
- redis基本操作
查看所有key:KEYS *
查看过期时间:TTL key
删除所有:flushall
获取key对应的值:GET key
四、模板
- 概念
- 模板是用户展示数据
- 模板处理(加载、渲染)
- 模板语法
- 变量 {{ var }}
视图传递数据给模板
变量不存在,即忽略
- 标签 {% tag %}
逻辑控制
- 条件控制 if
语法:
{% if 条件 %}
{% elif 条件%}
{% else %}
{% endif %}
- 循环控制 for
语法:
{% for name in names %}
有数据
{% else %}
没数据
{% endif %}
- 结构标签 block
- 语法 (挖坑、填坑)
{% block %}
{% endblock %}
# 继承后,想要保留其内容
{{ super() }}
- 结构标签 extends
- 语法(模板继承)
{% extends 'xxxx' %}
- 结构标签 include
- 语法
{% include 'xxx.html' %}
将一个大的页面,切分为一个个小的模块!通过include进行拼接!
- 宏定义 marco
- 语法
# 定义
{% marco run() %}
{% endmarco %}
# 调用
{{ run() }}
- 引入其他文件中的宏定义
{% from xxx import xxx %}
宏定义类似于函数,将重复的操作/重复的功能,封装起来,方便后续调用!
- 过滤器
- 默认值
default
- 小写
lower
- 大写
upper
- 关闭转义
safe
- 四舍五入
round
五、模型基本操作
- 模型概念
- flask默认并没有提供任何数据库操作API
- flask操作数据库,可以使用原生SQL语句,也可以使用ORM
- ORM 对象关系映射
- 只需要关注对象操作
- 性能提高
- 移植性比较好
flask-SQLAlchemy插件
- flask-sqlalchemy官网
- 安装插件
pip install flask-sqlalchemy
- 初始化(配置)
- 数据库配置
# /// 相对路径
# //// 绝对路径
app.config['SQLALCHEMY_DATABASE_URL'] = 'sqlite:///test.db'
- models.py中使用db
db = SQLAlchemy() # 实例化对象
- __init__.py中 和应用关联
db.init_app(app)
- 使用
# 定义模型
class User(db.Model):
id = db.Column(db.Integer,primary_key=True,autoincrement=True)
username = db.Column(db.String(80),unique=True)
age = db.Column(db.Integer)
# 创建表和数据库
db.create_all()
# 添加数据
db.session.add(user) # 添加
db.session.commit() # 写入数据库
# 查询数据
users = User.query.all()
在django中,默认id会自动添加,并且设置为主键自增长
flask模型中,必须设置主键,否则会报错!