1.Flask Request
request.form
request.args
request.data
request.json
request.files
request.method
request.path
request.host_url
request.cookies
request.headers
2.Flask Response
1."" HTTPResponse
2.render_templates(模板名称)
3.redirect("/路由地址")
Flask 特殊:
4.send_file("文件路径")
5.jsonify(dict)
3.Flask 中的 Session
from flask import session
application.secret_key = "$%^&*()&^%$%^&*"
app.config["SECRET_KEY"] = "$%^&*()&^%$%^&*"
session["user"] = 123
if session.get("user") --- session["user"] KeyError
交由客户端保管机制
1.session["user"] = "123"
2.序列化session 字符串
3.通过 SECRET_KEY 加密字符串 加密算法
4.cookie中加入 {SESSION_COOKIE_NAME}:SECRET_KEY 加密字符串
5.返回客户端
反:
1.Cookie获取{SESSION_COOKIE_NAME}:SECRET_KEY
2.通过 SECRET_KEY 解密 字符串 解密算法
3.反序列化 字符串 字典 - session
4.session.get("user")
4.路由
@app.route("/")
def index():
*endpoint app中是唯一的 路由和视图函数之间的桥梁
*methods 允许请求的方式 ["GET","POST","DELETE","PUT"]
**动态参数路由
"/index/<page>"
"/look/<xiaojiejie>/<picture>"
def look(xiaojiejie,picture):
defaults = {nid:1}
strict_slashes
redirect_to
app.add_url_rule()
5.初始化
app = Flask(__name__)
template_folder
static_folder
static_url_path
-import_name
-root_path
host_matching
static_host
subdomain_matching
instance_path
instance_relative_config
6.配置
app.config Flask Config对象
app.debug = True
app.config["DEBUG"] = True
DEBUG 开发环境 log级别低 重启代码错误透传
TESTING 测试环境 log级别较高
SECRET_KEY 开启Session序列化
SESSION_COOKIE_NAME 在Cookie Session名称
SESSION_COOKIE_HTTPONLY 是否只在HTTP请求下开启 session
JSONIFY_MIMETYPE 更改 jsonify 时的 Content-Type
class DebugConfig(object):
DEBUG = True
SECRET_KEY = "%^&*()_"
app.config.from_object(DebugConfig)
7.蓝图
蓝图就是不能Run的Flask示例
蓝图中没有Config对象
蓝图的作用 隔离应用 隔离路由
bp = Blueprint("蓝图名称全Flask示例唯一",__name__)
@bp.route("application路由一致",url_prefix="/url前缀")
def bp_index():
app.register_blueprint(bp
8.特殊装饰器
@app.before_request
@app.after_request
正常:be1 - be2 - vf - af2 - af1
异常:be1 - af2 - af1
@app.errorhandler(404)
def error404(ErrorMessage):
return 5返回
@app 可是 @bp , @bp 当前的装饰器只生效当前 bp
9.CBV
试图类
from flask import views 导入CBV的视图基类
class Login(views.MethodView):
def get(self):
return "GET 200 OK!"
def post(self):
return "POST 200 OK!"
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架