一、会话技术cookie
- 概述
客户端的会话技术
所有数据都在客户端
存储方式key-value
cookie浏览器自动携带本站数据
cookie支持过期时间s
- 设置cookie
response.set_cookie(key,value)
- 获取cookie
request.cookies.get(key)
- 删除cookie
response.delete_cookie(key)
二、会话技术session
- 概述
服务端的会话技术
所有数据都在服务器
存储在内存中 【未做持久化处理】
session 是依赖于 cookie
如果要使用session,必须设置秘钥: app.config['SECRET_KEY'] = '%&*(FGhjk1231adfqskdGFHJK$%&*'
- 设置session
session[key] = value
- 获取session
session.get(key)
- 删除session
session.pop(key)
三、flask-session插件
- 概述
- flask中session默认是内存(django默认持久化存储是在数据库)
- flask-session 可以实现session持久化存储
- 官网
https://pythonhosted.org/Flask-Session/
- 安装
pip install Flask-Session
- 初始化
# 必选
app.config['SESSION_TYPE'] = 'redis' # session持久化策略 redis [redis/memcached/filesystem/mongodb/sqlalchemy]
# 可选 (客户端显示 key)
app.config['SESSION_COOKIE_NAME'] = 'sessionid_uu'
# 可选 (过期时间)
app.config['PERMANENT_SESSION_LIFETIME'] = 60
# 方式一
Session(app) # 实例化Session对象
# 方式二
sess = Session()
sess.init_app(app)
注意: redis服务要开启!!!
- 使用
和系统session使用一模一样,即只要配置要插件,源代码无需做任何修改!
- redis基本操作
查看所有key: KEYS *
查看过期时间: TTL key
删除所有: FLUSHALL
获取key对应的值: GET key
四、模板
- 概念
- 模板是用户展示数据
- 模板处理(加载、渲染)
- 模板语法
- 变量 {{ var }}
视图传递数据给模板
变量不存在,即忽略
- 标签 {% tag %}
逻辑控制
- 条件控制if
- 语法
{% if 条件 %}
语句
{% elif 条件 %}
语句
..
{% else %}
语句
{% endif %}
- 例如
{% if username and username == 'root' %}
<p style="color: red;"> 超级用户! </p>
{% elif username %}
<p> 用户:{{ username }} </p>
{% else %}
<p> 请注册后操作(未登录)! </p>
{% endif %}
- 循环控制for
- 语法
{% for xx in xxx %}
有数据
{% else %}
没有数据
{% endfor %}
- 例如
<ul>
{% for name in names %}
{% if loop.first %}
<li style="color: blue"> {{ loop.index }}-{{ name }} </li>
{% elif loop.last %}
<li style="color: red"> {{ loop.index }}-{{ name }} </li>
{% else %}
<li style="color: pink"> {{ loop.index }}-{{ name }} </li>
{% endif %}
{% else %}
<p style="color: red"> 哥们,你还没传递数据过来! </p>
{% endfor %}
</ul>
- 结构标签 block
- 语法 (挖坑、填坑)
{% block xxxx %}
{% endblock %}
# 继承后,想要保留其内容
{{ supper() }}
- 例如
{% block extcss %}
{{ super() }}
<link rel="stylesheet" href="/static/css/home.css">
{% endblock %}
- 结构标签 extends
- 语法 (模板继承)
# 继承
{% extends 'xxxx' %}
- 结构标签 include
- 语法:
{% include 'xxx.html' %}
将一个非常大的页面,切分为一个个小的模块,通过include进行拼接!
- 宏定义 marco
- 语法
{% macro 名称 %}
具体代码
{% endmacro %}
- 引入其他文件分中的宏定义
{% from xxx import xxx %}
宏定义类似于函数,将重复的操作/重复的功能,封装起来,方便后续调用!
- 过滤器
{# 当变量未定义时,显示默认字符串,可以缩写为d #}
<p>{{ name | default('No name') }}</p>
{# 单词首字母大写 #}
<p>{{ 'hello' | capitalize }}</p>
{# 单词全小写 #}
<p>{{ 'XML' | lower }}</p>
{# 去除字符串前后的空白字符 #}
<p>{{ ' hello ' | trim }}</p>
五、模型基本操作
- 模型概念
- flask默认并没有提供任何数据库操作API
- flask操作数据库,可以使用原生SQL语句,页可以使用ORM
- ORM 对象关系映射
- 只需要关注对象操作
- 性能提高
- 移植性比较好
flask-SQLAlchemy插件
- flask-sqlalchemy官网
中文文档: http://www.pythondoc.com/flask-sqlalchemy/quickstart.html
英文文档: http://flask-sqlalchemy.pocoo.org/2.3/
- 安装插件
pip install flask-sqlalchemy
- 初始化(配置)
- 数据库配置 __init__.py
# /// 相对路径
# //// 绝对路径
# app.config['SQLALCHE_DATABASE_URI'] = 'sqlite:///../test.db'
app.config['SQLALCHE_DATABASE_URI'] = '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)
name = db.Column(db.String(40), unique=True)
age = db.Column(db.Integer)
# 创建表和数据库
db.create_all()
# 添加数据
db.session.add(xxx)
db.session.commit()
# 查询数据
Xxxx.query.all()
flask模型中,必须设置主键,否则会报错!!!