flask会话技术详解及模板使用

一、会话技术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' %}
        

超级用户!

{% elif username %}

用户:{{ username }}

{% else %}

请注册后操作(未登录)!

{% endif %}
  • 循环控制for
- 语法
    {% for xx in xxx %}
        有数据
    {% else %}
        没有数据
    {% endfor %}

- 例如
    
    {% for name in names %} {% if loop.first %}
  • {{ loop.index }}-{{ name }}
  • {% elif loop.last %}
  • {{ loop.index }}-{{ name }}
  • {% else %}
  • {{ loop.index }}-{{ name }}
  • {% endif %} {% else %}

    哥们,你还没传递数据过来!

    {% endfor %}
  • 结构标签 block
- 语法 (挖坑、填坑)
    {% block xxxx %}
    {% endblock %}

    # 继承后,想要保留其内容
    {{ supper() }}

- 例如
    {% block extcss %}
        {{ super() }}
        
    {% endblock %}
  • 结构标签 extends
- 语法 (模板继承)
    # 继承
    {% extends 'xxxx' %}
  • 结构标签 include
- 语法:
    {% include 'xxx.html' %}

将一个非常大的页面,切分为一个个小的模块,通过include进行拼接!

  • 宏定义 marco
- 语法
    {% macro 名称 %}
        具体代码
    {% endmacro %}

- 引入其他文件分中的宏定义
    {% from xxx import xxx %}

宏定义类似于函数,将重复的操作/重复的功能,封装起来,方便后续调用!

  • 过滤器
{# 当变量未定义时,显示默认字符串,可以缩写为d #}

{{ name | default('No name') }}

{# 单词首字母大写 #}

{{ 'hello' | capitalize }}

{# 单词全小写 #}

{{ 'XML' | lower }}

{# 去除字符串前后的空白字符 #}

{{ ' hello ' | trim }}

五、模型基本操作

  • 模型概念
- 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模型中,必须设置主键,否则会报错!!!

你可能感兴趣的:(flask会话技术详解及模板使用)