Python Flask 学习笔记

1. Flask Hello world

from flask import Flask

# app = Flask(__name__) 默认是static
app = Flask(__name__, static_url_path="/s", static_folder="test1")


@app.route('/')
def hello_world():
    return 'Hello World'


if __name__ == '__main__':
    app.run()

2. 调用参数信息

  • 方法一,方便继承复用

    app.config.from_object(DefaultConfig)

  • 方法二,独立文件保护敏感数据

    app.config.from_pyfile("setting1.py")

  • 方法三,设置环境变量

    app.config.from_envvar("ENV1")

from flask import Flask


class DefaultConfig(object):
    SECRUITY_KEY = "QASDRFTGYUYTREWQTY"


app = Flask(__name__, static_url_path="/s", static_folder="test1")

# 方法一,方便继承复用
# app.config.from_object(DefaultConfig)
# 方法二,独立文件保护敏感数据
# app.config.from_pyfile("setting1.py")
# 方法三,设置环境变量
app.config.from_envvar("ENV1")

@app.route('/')
def hello_world():
    # 读取配置信息
    return app.config["SECRUITY_KEY"]


if __name__ == '__main__':
    app.run()

setting1.py

SECRUITY_KEY = "dfghjhdesdfgbh`12567"

3. app.run()替代

修改默认配置

image-20210708190136670.png

app.url_map

import json

from flask import Flask


def create_flask_app(config):
    app = Flask(__name__, static_url_path="/s", static_folder="test1")
    app.config.from_object(config)
    return app

class DefaultConfig(object):
    SECRUITY_KEY = "QASDRFTGYUYTREWQTY"

class DevelopmentConfig(DefaultConfig):
    DEBUG = True

app = create_flask_app(DevelopmentConfig)

@app.route('/')
def hello_world():
    # 读取配置信息
    return app.config["SECRUITY_KEY"]

@app.route("/url")
def url():
    urls = app.url_map.iter_rules()
    return json.dumps({url.endpoint: url.rule for url in urls})

# print(app.url_map)

for url in app.url_map.iter_rules():
    print(f"name={url.endpoint}, path={url.rule}")
# if __name__ == '__main__':
#     app.run(host="0.0.0.0", port=5000)

4. 蓝图

image-20210708190429374.png
from flask import Flask, Blueprint

app = Flask(__name__, static_url_path="/s", static_folder="test1")

# 创建蓝图对象
user_bp = Blueprint("user", __name__)


@user_bp.route("/profile", methods=["POST"])
def get_profile():
    return "user profile"


# 注册蓝图
# 127.0.0.1:5000/profile
# app.register_blueprint(user_bp)
# 127.0.0.1:5000/user/profile
app.register_blueprint(user_bp, url_prefix="/user")

from goods import goods_bp
app.register_blueprint(goods_bp, url_prefix="/goods")


if __name__ == '__main__':
    app.run()

_init_.py

from flask import Blueprint

goods_bp = Blueprint("goods", __name__, )

from . import views

view.py

from . import goods_bp

@goods_bp.route("/good")
def getGoods():
    return "goods"

5. URL路径参数

image-20210708205052019.png
from flask import Flask, request
from werkzeug.routing import BaseConverter

class MobileConverter(BaseConverter):
    regex = r"1[3-9]\d{9}"

app = Flask(__name__)

app.url_map.converters["mobile"] = MobileConverter

# @app.route('/users/<usr_id>')
@app.route('/users/<int:usr_id>')
def getUserId(usr_id):
    print(type(usr_id))
    return f'usr id: {usr_id}'

@app.route('/phone/<mobile:mon_num>')
def getMobile(mon_num):
    print(type(mon_num))
    return f'mobile number: {mon_num}'

# /articles?channerl_id=123
@app.route("/articles")
def getActiclr():
    channel_id = request.args.get("channerl_id")
    return f"channerl id: {channel_id}"

@app.route("/upload", methods=["POST"])
def uploadFile():
    file = request.files["pic"]
    # with open("./demo.png", "wb") as nf:
    #     nf.write(file.read())
    file.save("./demo.png")
    return "ok"

if __name__ == '__main__':
    app.run()

6. 模板响应

templates/index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
hhhhhhhhhhhhhhhhhhhhhhhhh
<br/>{{my_str}}
<br/>{{my_int}}
asxdcfghjkl;
</body>
</html>

py

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def home():
    mint = 1234
    mstr = "asdfvgbn"
    data = dict(
        my_int = 1234,
        my_str = "12345tgbfdsa"
    )
    # return render_template("index.html", my_str=mstr, my_int=mint)
    return render_template("index.html", **data)

if __name__ == '__main__':
    app.run()

7. 返回json

from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/')
def rejson():
    data = dict(
        my_int = 1234,
        my_str = "12345tgbfdsa"
    )
    return jsonify(data)

if __name__ == '__main__':
    app.run()

8. 构造响应状态

from flask import Flask, make_response

app = Flask(__name__)

@app.route('/re1')
def re1():
    return "state", 666, {"name": "kdk"}

@app.route('/re2')
def re2():
    resp = make_response("body")
    resp.headers["name"] = "hdk"
    resp.status = "404 good"
    return resp

if __name__ == '__main__':
    app.run()

9. cookie 和 session

from flask import Flask, make_response, request, session

class DefaultConfig(object):
    SECRET_KEY = "QASDRFTGYUYTREWQTY"

app = Flask(__name__)
app.config.from_object(DefaultConfig)

@app.route('/cooke')
def setCookie():
    resp = make_response("set cookie hdk")
    resp.set_cookie("name1", "hdk")
    return resp

@app.route('/getcooke')
def getCookie():
    resp = request.cookies.get("name1")
    return resp

@app.route('/deleteCooke')
def deleteCookie():
    resp = make_response("set cookie hdk")
    resp.delete_cookie("name1", "hdk")
    return resp

@app.route('/setSession')
def setSession():
    session["name2"] = "hddk"
    return "seesion ok"

@app.route('/getSession')
def getSession():
    name = session.get("name2")
    return f"seesion: {name}"


if __name__ == '__main__':
    app.run()

10. 异常处理

from flask import Flask, request, abort

app = Flask(__name__)

# abort
@app.route("/articles")
def getActiclr():
    channel_id = request.args.get("channerl_id")
    if channel_id is None:
        abort(400)
    return f"channerl id: {channel_id}"

# code error
@app.errorhandler(500)
def internal_sever_error(e):
    return "Sever remove"

# catch error
@app.errorhandler(ZeroDivisionError)
def zero_division(e):
    print(e)
    return "can't 0"

@app.route("/o")
def getResult():
    r = 1/0
    return f"ok{r}"

if __name__ == '__main__':
    app.run()

11.请求钩子

启动中间件

from flask import Flask

app = Flask(__name__)

@app.before_first_request
def before_first_request():
    print("before_first_request")

@app.before_request
def before_request():
    print("before_request")

@app.after_request
def after_request(response):
    print("after_request")
    response.headers["Content-Type"] = "application/json"
    return response

@app.teardown_request
def teardown_request(response):
    print("teardown_request")

@app.route("/")
def index():
    print("view")
    return "index"

if __name__ == '__main__':
    app.run()

12. 上下文

from flask import Flask, current_app, g

app1 = Flask(__name__)
app2 = Flask(__name__)

#redis-cli
app1.redis_cli = "redis client1"
app2.redis_cli = "redis client2"


@app1.route('/app1')
def fetApp1():
    return f"{current_app.redis_cli}"

@app2.route('/app2')
def fetApp2():
    return f"{current_app.redis_cli}"

def db_query():
    uid = g.user_id
    uname = g.user_name
    return f"db result: {uid}, {uname}"

# g对象
@app1.route('/user')
def getUser():
    g.user_id = 123
    g.user_name = "hdk"
    return db_query()


from application import bp
app1.register_blueprint(bp)


if __name__ == '__main__':
    # only one
    app1.run()
    # app2.run()

application.py

from flask import Blueprint, current_app

bp = Blueprint("blue1", __name__)

@bp.route('/bp1')
def viewFunc():
    print(current_app.redis_cli)
    return "ok"

13. 认证机制

  • 特定强制需求->装饰器
  • 所有试图的需求->钩子
from flask import Flask, g, abort

app = Flask(__name__)

@app.before_request
def auth():
    g.user_id = 123
    # g.user_id = None


def login_required(func):
    def wrapper(*args, **kwargs):
        if g.user_id is None:
            abort(401)
        else:
            return func(*args, **kwargs)
    return wrapper

@app.route("/")
def index():
    print("view")
    return f"user is {g.user_id}"

@app.route("/profile")
@login_required
def getUserProfile():
    return f"user profile {g.user_id}"


if __name__ == '__main__':
    app.run()
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,063评论 6 510
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,805评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,403评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,110评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,130评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,877评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,533评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,429评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,947评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,078评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,204评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,894评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,546评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,086评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,195评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,519评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,198评论 2 357

推荐阅读更多精彩内容