flask02

一、会话技术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模型中,必须设置主键,否则会报错!

你可能感兴趣的:(flask02)