这两天稍微接触了一点 Flask 框架,所以分享点基础

1. 配置文件

from flask import Flask

app = Flask(__name__)
# 使用自定义的配置文件
app.config.from_object('settings.Config')
"""
# 内部原理 : con = 'settings.Config'
- a,b = con.rsplit('.',maxsplit=1) # 将字符分割
- m = importlib.import_module(a) # 导入settings模块
- class = getattr(m.b) # 拿到settings下的类
""" @app.route('/index')
def index(): return 'index' if __name__ == '__main__':
# print(app.config) # 打印 Flask 下的配置属性
app.run() ################### 配置文件.py #################### class Config(object):
DEBUG = False class ProductionConfig(Config): # 线上环境使用的配置
DEBUG = False class DevelopmentConfig(Config): # 开发环境下使用
DEBUG = True

2. 路由系统

from flask import Flask,render_template,request,redirect,session,url_for

app = Flask(__name__)

"""
endpoint=名字
这个名字就指代了当前视图函数的 url 地址 如果不写 endpoint 那么 url_for 反向解析的默认值就是当前视图函数的名字
- url_for('index')
""" # @app.route('/index',methods=['GET','POST'],endpoint='q1')
@app.route('/index/<int:nid>',methods=['GET','POST'])
def index(nid):
"""
nid -- 接收上面 url 中的参数
接收参数类型:
- @app.route('/index<username>') # 字符
- @app.route('/index<int:nid>') # 整数
- @app.route('/index<float:nid>') # 浮点
- @app.route('/index<path:path>') # 路径
:param nid:
:return:
"""
# print(url_for('q1')) # 反向解析 url : /index
# print(url_for('index')) # 默认 函数名 : /index
# print(url_for('index',nid=333)) # /index/333
return 'INDEX' if __name__ == '__main__':
app.run()

3. 请求和响应

from flask import Flask, render_template, request, redirect, session, url_for, jsonify, make_response

app = Flask(__name__)

@app.route('/index', methods=['GET', 'POST'])
def index():
"""
常用 响应方式
return 'INDEX'
return jsonify({'k1':k2})
return render_template()
return redirect()
:return:
"""
# 设置响应头
obj = make_response('Index') # 把要返回的字符串,封装到对象中
obj.headers['headers_q'] = 'xxx'
obj.set_cookie('k1','v1')
return obj if __name__ == '__main__':
app.run()

4. 模板

"""

    模板渲染:
- 1. 标签解析:
方式一:{{txt|safe}}
方式二:MarpUp -- Markup("<input type='text' />")
- 2. 在模板进行函数调用
方式一:自定义一个函数,然后变成参数传递 -- {{fn(7)}}
方式二:使用 @app.template_global() 来定义一个全局的函数,在所有模板都可用(加括号) -- {{fn1(1,2)}}
方式二:使用 @app.template_filter() 来定义一个全局的函数,在所有模板都可用(加括号) -- {{4|fn2(6,7)}}
- 3. 模板继承:
- 父模板:{% block content %} {% endblock %}
- 子模版:{% extends 'base.html' %}
{% block content %}
{% endblock %} - 4. 在模块中定义 宏
{% macro a(name,type='text',value='') %}
<h1>宏</h1>
<input type="{{type}}" name="{{name}}" value="{{value}}">
{% endmacro %}
{{a('q')}}
"""
from flask import Flask,render_template,request,redirect,session,url_for,jsonify,make_response,Markup,flash,get_flashed_messages app = Flask(__name__) # 全局函数(加括号) - 可以任何模板中使用
@app.template_global()
def fn1(a1,a2):
return a1+a2 # 参数放的方式不一样,可以用于判断条件
@app.template_filter()
def fn2(a1,a2,a3):
return a1+a2+a3 def fn(arg):
return arg @app.route('/index',methods=["GET","POST"])
def index():
print('index')
info = {
'lis':[1,2,3],
'txt':"<input type='text' />",
'txt1':Markup("<input type='text' />"),
'fn':fn
}
return render_template('models.html',**info) if __name__ == '__main__':
app.run()

5. session 简单了解

"""
# 当请求刚到来的时:flask 读取cookie 中对应的值,将值解密,并放反序列化成字典,放入内存,以便视图函数使用
# 当请求结束时,flask 会读取内存中字典的值,进行序列化和加密,写入 Cookie 中 - 只能取一次 session 值:
from flask import Falsk, flash, get_fiashed_messages flash('k1') -- 存放一个值到 session 中
- 可以分类:
flash('k1','error')
flash('k2','error')
flash('k3','info')
get_flashed_messages() -- 只能获取一次 session 的值
- 可以只拿分类中的数据
get_flashed_messages(category_filter=['error'])
"""

6. 特殊装饰器 -- 类似于 Django 中的中间件

from flask import Flask
app = Flask(__name__) """
执行顺序:
1. before -> Index -> after
2. before1 -> before2 -> Index -> after2 -> after1
3. before1(如果return) --> after2 -> after1 定制错误页面:
@app.errorhandler(404)
def not_found(arg):
return xxx.html """ @app.before_request
def x1():
print('before') @app.after_request
def x2(response):
print('after')
return response @app.route('/index')
def index():
print('index')
return 'Index' if __name__ == '__main__':
app.run()

7. 中间件

"""
- call 触发条件:
- 用户发起请求时执行
"""
from flask import Flask
app = Flask(__name__) class Middleware(object):
def __init__(self,old):
self.old = old def __call__(self, *args, **kwargs):
ret = self.old(*args, **kwargs)
return ret if __name__ == '__main__':
app.wsgi_app = Middleware(app.wsgi_app)
app.run()

持续更新...

python - Flask 基础(1)的更多相关文章

  1. python flask 基础入门

    1. Flask 中的Hello World! 在使用pycharm创建一个Flask项目后,将会默认创建一个flask的app,这里来讲下每行代码表示的意义,代码入下 from flask impo ...

  2. python - Flask 基础 - 蓝图( Blueprint )(2)

    """ 蓝图:为开发者提供的目录结构 - 使用: 1. 根目录创建一个跟项目名一样的文件 - 创建后第一步,在这个文件夹中添加一个 __init__.py 的配置文件 - ...

  3. 知了课堂 Python Flask零基础 笔记整理

    目录 起步 安装Python2.7: Python虚拟环境介绍与安装: pip安装flask: 认识url: URL详解 web服务器和应用服务器以及web应用框架: Flask 第一个flask程序 ...

  4. [Python][flask][flask-login]关于flask-login中各种API使用实例

    本篇博文跟上一篇[Python][flask][flask-wtf]关于flask-wtf中API使用实例教程有莫大的关系. 简介:Flask-Login 为 Flask 提供了用户会话管理.它处理了 ...

  5. python Flask

    python Flask Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请 ...

  6. Python Flask Restful

    Flask  Restful 1.flask restful 在flask基础上进行一些封装,主要用于实现restful接口 2.restful的理解 1)URI(统一资源标识符):每一个URI代表一 ...

  7. Python+Flask+MysqL的web建设技术过程

    一.前言(个人学期总结) 个人总结一下这学期对于Python+Flask+MysqL的web建设技术过程的学习体会,Flask小辣椒框架相对于其他框架而言,更加稳定,不会有莫名其妙的错误,容错性强,运 ...

  8. flask基础之jijia2模板语言进阶(三)

    前言 前面学习了jijia2模板语言的一些基础知识,接下来继续深挖jijia2语言的用法. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) 控制语句 和 ...

  9. flask基础之jijia2模板使用基础(二)

    前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...

随机推荐

  1. LeetCode 378. 有序矩阵中第K小的元素(Kth Smallest Element in a Sorted Matrix) 13

    378. 有序矩阵中第K小的元素 378. Kth Smallest Element in a Sorted Matrix 题目描述 给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩 ...

  2. 【转帖】linux date 显示指定时区的时间 借助TZ 环境变量 export TZ=Asia/Shanghai 或 America/New_York

    linux date 显示指定时区的时间 借助TZ 环境变量 export TZ=Asia/Shanghai 或 America/New_York 2015-02-10 10:58:22 youcha ...

  3. MongoDB的Shell操作

    前言 本文从介绍了MongoShell 的配置.脚本.数据类型和其他指令. MongoShell - 简介 MongoShell是一个互动的JavaScript接口的MongoDB,可以使用Mongo ...

  4. SSM基本案例

    1.搭建环境,导入maven依赖 <properties> <project.build.sourceEncoding>UTF-8</project.build.sour ...

  5. C++ 重载运算符返回值 和 返回引用的原因

    原因是: +,-,*等返回不了引用,比如+运算符,可以如下重载(为了简单,假设A 只有int x:int y) A operator+(A a,A b) {A sum;   sum.x=a.x+b.x ...

  6. nfs挂载文件

    1. 安装必备插件  以防centos7默认没有启动nfs服务 yum -y install nfs-utils rpcbind # 启动 rpcbind 和配置开机自启动 systemctl sta ...

  7. Spring Cloud Alibaba学习笔记(11) - RocketMQ事务消息

    在Spring中,我们要实现事务,一般通过@Transactional注解实现.这在引入RocketMQ之前没有问题,但是在引入了RocketMQ之后,如果消息发送之后的业务逻辑处理发生了异常的话,这 ...

  8. [转载] jmeter Bean Shell的使用

    Jmeter有哪些Bean Shell 定时器: BeanShell Timer 前置处理器:BeanShell PreProcessor 采样器: BeanShell Sampler 后置处理器:B ...

  9. win7 ReadyBoot 文件位置修改

    右键我的电脑,依次点开系统工具-性能-数据收集器集-系统-事件跟踪会话 在右边找到ReadyBoot,右键打开属性,会话框上方选择文件,根据示例文件名的路径找到ReadyBoot.etl文件,复制到你 ...

  10. nginx热加载、热升级、回滚

    修改完配置文件后使用 nginx -s reload 命令进行热加载 编译好新的 nginx 二进制文件后,运行nginx 开启nginx服务,然后使用 kill -USR2 新的nginx_mast ...