python web flask专题-Flask入门指南:从安装到核心功能详解

Flask入门指南:从安装到核心功能详解

Flask作为Python最流行的轻量级Web框架之一,以其简洁灵活的特性广受开发者喜爱。本文将带你从零开始学习Flask,涵盖安装配置、项目结构、应用实例、路由系统以及请求响应处理等核心知识点。
在这里插入图片描述

1. Flask安装与项目结构

1.1 安装Flask

在开始之前,请确保已安装Python(建议3.6+版本)。通过pip安装Flask:

pip install flask

验证安装是否成功:

python -c "import flask; print(flask.__version__)"

1.2 最小Flask应用

创建一个最简单的Flask应用app.py

from flask import Flaskapp = Flask(__name__)@app.route('/')
def hello():return 'Hello, World!'if __name__ == '__main__':app.run(debug=True)

运行应用:

python app.py

访问http://127.0.0.1:5000即可看到"Hello, World!"。

代码解释

  • Flask(__name__)创建应用实例,__name__确定应用根目录
  • @app.route('/')装饰器定义路由
  • app.run(debug=True)启动开发服务器,debug=True启用调试模式

1.3 基本项目结构

随着项目增长,推荐的组织结构:

/flask_project/app/static       # 静态文件(CSS, JS, 图片)/templates    # 模板文件(HTML)__init__.py   # 应用工厂函数routes.py     # 路由定义models.py     # 数据模型config.py         # 配置文件requirements.txt  # 依赖列表

2. Flask应用实例配置详解

2.1 应用工厂模式

使用工厂函数创建应用更灵活:

# app/__init__.py
from flask import Flask
from . import routesdef create_app(config_filename=None):app = Flask(__name__)# 加载配置if config_filename:app.config.from_pyfile(config_filename)else:app.config.from_mapping(SECRET_KEY='dev',DATABASE='sqlite:///app.db',)# 注册蓝图或路由app.register_blueprint(routes.bp)return app

2.2 常用配置项

Flask配置可以通过多种方式设置:

# 直接设置
app.config['SECRET_KEY'] = 'your-secret-key'# 从对象加载
class Config:SECRET_KEY = 'your-secret-key'DEBUG = True
app.config.from_object(Config)# 从文件加载
app.config.from_pyfile('config.py')# 常用配置项:
# DEBUG - 是否启用调试模式
# TESTING - 是否启用测试模式
# SECRET_KEY - 加密会话的密钥
# SESSION_COOKIE_NAME - 会话cookie名称
# PERMANENT_SESSION_LIFETIME - 持久会话有效期

3. 路由定义详解

3.1 基本路由

@app.route('/')
def index():return '首页'@app.route('/about')
def about():return '关于我们'

3.2 动态路由

@app.route('/user/<username>')
def show_user(username):return f'用户: {username}'@app.route('/post/<int:post_id>')
def show_post(post_id):return f'文章ID: {post_id}'

路由转换器类型

  • string: (默认)接受任何不包含斜线的文本
  • int: 接受正整数
  • float: 接受正浮点数
  • path: 类似string但包含斜线
  • uuid: 接受UUID字符串

3.3 HTTP方法

@app.route('/login', methods=['GET', 'POST'])
def login():if request.method == 'POST':return do_login()else:return show_login_form()

3.4 URL生成

使用url_for()生成URL:

from flask import url_for@app.route('/')
def index():print(url_for('login'))  # 输出: /loginprint(url_for('show_user', username='john'))  # 输出: /user/johnreturn '首页'

4. 请求与响应处理

4.1 请求对象(Request)

Flask自动将请求数据封装在request对象中:

from flask import request@app.route('/search')
def search():query = request.args.get('q', '')  # 获取查询参数return f'搜索: {query}'@app.route('/submit', methods=['POST'])
def submit():username = request.form['username']  # 获取表单数据file = request.files['avatar']      # 获取上传文件return f'用户名: {username}'

常用request属性

  • args: GET请求参数 (查询字符串)
  • form: POST表单数据
  • files: 上传的文件
  • headers: 请求头
  • method: 请求方法
  • json: 解析后的JSON数据

4.2 响应对象(Response)

视图函数可以返回多种类型的响应:

from flask import make_response, jsonify, redirect# 返回字符串
@app.route('/text')
def text_response():return '纯文本响应'# 返回JSON
@app.route('/json')
def json_response():return jsonify({'status': 'success', 'data': [1, 2, 3]})# 自定义响应
@app.route('/custom')
def custom_response():response = make_response('自定义响应')response.headers['X-Custom-Header'] = 'Value'response.status_code = 201return response# 重定向
@app.route('/old')
def old_route():return redirect('/new')

4.3 处理文件上传

from werkzeug.utils import secure_filename@app.route('/upload', methods=['POST'])
def upload_file():if 'file' not in request.files:return '没有文件部分'file = request.files['file']if file.filename == '':return '没有选择文件'if file and allowed_file(file.filename):filename = secure_filename(file.filename)file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))return '文件上传成功'

4.4 处理Cookie

@app.route('/set-cookie')
def set_cookie():resp = make_response('设置Cookie')resp.set_cookie('username', 'john', max_age=3600)return resp@app.route('/get-cookie')
def get_cookie():username = request.cookies.get('username')return f'用户名: {username}'

5. 总结

通过本文的学习,你应该已经掌握了Flask的核心基础知识:

  1. 安装与项目结构

    • 使用pip安装Flask
    • 合理组织项目目录结构
    • 理解最小Flask应用的构成
  2. 应用实例配置

    • 使用工厂模式创建应用
    • 掌握多种配置方式
    • 了解常用配置项
  3. 路由系统

    • 定义静态和动态路由
    • 处理不同的HTTP方法
    • 使用url_for()生成URL
  4. 请求与响应

    • 访问请求数据(request对象)
    • 构建各种类型的响应
    • 处理文件上传和Cookie

Flask的简洁性使其成为学习Web开发的理想框架,但其扩展性又能满足复杂应用的需求。建议在掌握这些基础知识后,继续学习以下内容:

  • 模板渲染(Jinja2)
  • 数据库集成(Flask-SQLAlchemy)
  • 用户认证(Flask-Login)
  • 使用蓝图(Blueprint)组织大型应用
  • 部署Flask应用到生产环境

记住,最好的学习方式是实践 - 尝试用Flask构建一个小型项目,如博客系统或待办事项应用,将帮助你巩固这些概念。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/pingmian/82510.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一种C# 的SM4 的 加解密的实现,一般用于医疗或者支付

一种C# 的SM4 的 加解密的实现 一般用于医疗或者支付 加密 string cipherText SM4Helper.Encrypt_test(data, key); public static string Encrypt_test(string plainText, string key) { byte[] keyBytes Encoding.ASCII.GetBytes(key); byte[] input…

“轩辕杯“云盾砺剑CTF挑战赛 Web wp

文章目录 ezflaskezjsezrceezssrf1.0签到ezsql1.0ez_web1非预期预期解 ezflask ssti, 过滤了一些关键词, 绕一下就行 name{{url_for["__globals__"]["__builtins__"]["eval"]("__tropmi__"[::-1])(os)["po""pen"…

Matlab快速上手五十六:详解符号运算里假设的用法,通过假设可以设置符号变量的取值范围,也可以通过假设设置变量属于集合:整数、正数和实数等

1.符号变量中假设的概念 在符号数学工具箱中&#xff0c;符号变量默认范围是全体复数&#xff0c;也就是说&#xff0c;符号运算是在全体复数域进行的&#xff0c;若需要运算中&#xff0c;不使用全体复数域&#xff0c;可以为变量设定取值范围&#xff0c;这就用到了假设&…

【python实用小脚本-79】[HR转型]Excel难民到数据工程师|用Python实现CSV秒转JSON(附HRIS系统对接方案)

场景故事&#xff1a;从手动复制粘贴到自动化数据流转 "Kelly&#xff0c;我们需要把3000名员工的考勤数据导入新HR系统&#xff0c;今天能完成吗&#xff1f;"去年这个时候&#xff0c;作为HRIS项目负责人的我&#xff0c;面对这个需求时第一反应是打开Excel开始手…

数据透视:水安 B 证如何影响水利企业的生存指数?

某大数据公司提取了 3000 家水利企业的经营数据&#xff0c;一组关联分析令人震惊&#xff1a;B 证配备率与企业利润率的相关系数达 0.67—— 这意味着持证率每提升 10%&#xff0c;企业利润率平均提高 4.2 个百分点。当我们用数据解剖这本红本本&#xff0c;会发现它像一根无形…

从零搭建上门做饭平台:高并发订单系统设计

你知道为什么聪明人都在抢着做上门做饭平台吗&#xff1f;因为这可能是餐饮行业最后一片蓝海&#xff01;传统餐饮还在为房租人工发愁时&#xff0c;上门私厨已经轻装上阵杀出重围。不需要门店租金&#xff0c;不用养服务员&#xff0c;厨师直接上门服务&#xff0c;成本直降60…

openpi π₀ 项目部署运行逻辑(四)——机器人主控程序 main.py — aloha_real

π₀ 机器人主控脚本都在 examples 中&#xff1a; 可以看到包含了多种类机器人适配 此笔记首先记录了 aloha_real 部分 aloha_real 中&#xff0c;main.py 是 openpi ALOHA 平台上“主控执行入口”&#xff0c;负责&#xff1a; 建立与推理服务器&#xff08;serve_policy.…

利用 Python 爬虫获取唯品会 VIP 商品详情:实战指南

在当今电商竞争激烈的环境中&#xff0c;VIP 商品往往是商家的核心竞争力所在。这些商品不仅代表着品牌的高端形象&#xff0c;更是吸引高价值客户的关键。因此&#xff0c;获取 VIP 商品的详细信息对于市场分析、竞品研究以及优化自身产品策略至关重要。Python 作为一种强大的…

鸿蒙桌面快捷方式开发

桌面快捷方式开发实战 [参考文档] (https://developer.huawei.com/consumer/cn/doc/best-practices/bpta-desktop-shortcuts) 在module.json5配置文件中的abilities标签下的metadata中设置resource属性值为$profile:shortcuts_config&#xff0c;指定应用的快捷方式配置文件&…

3分钟学会跨浏览器富文本编辑器开发:精准光标定位+内容插入(附完整代码)

一、痛点直击&#xff1a;传统编辑器的三大坑 作为前端开发&#xff0c;你是否遇到过以下灵魂拷问&#xff1f; ✅ 为什么Firefox光标能精准定位&#xff0c;IE却永远跳转到开头&#xff1f;✅ 图片上传后如何保证插入位置不偏移&#xff1f;✅ 跨浏览器兼容测试时&#xff0…

RK3562 Linux-5.10 内核HUSB311 Type-C 控制器芯片调试记录

硬件原理&#xff1a; 1. type C 接口&#xff1a; 1.1 HUSB311芯片&#xff0c; CC1和CC2 逻辑接到HUSB311 上面&#xff0c; 接I2C0组和USBCC_INT_L USBCC_INT_L 接到GPIO0_A6 做为CC的逻辑中断 1.2 TYPEC_DP/TYPEC_DM 接到ARM 端的USB3.0 OTG上面 1.2 TYPEC_RX1P/TYPEC…

深入理解Java中的BigDecimal:高精度计算的核心工具

精心整理了最新的面试资料和简历模板&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 引言 在Java编程中&#xff0c;处理浮点数运算时可能会遇到精度丢失的问题。例如&#xff1a; System.out.println(0.1 0.2); // 输出&#xff1a;0.30000…

大模型微调(面经总结)

持续更新中 一、LORA篇1、介绍一下Lora的原理2、LoRA 是为了解决什么问题提出的&#xff1f;哪些模型适合用 LoRA 微调&#xff1f;什么是低秩分解&#xff1f;**低秩分解&#xff1a;用小矩阵逼近大矩阵** 3、LoRA初始化4、LoRA初始化秩 r 是怎么选的&#xff1f;为什么不选其…

Camera相机人脸识别系列专题分析之一:人脸识别系列专题SOP及理论知识介绍

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a;内存泄漏和内存占用拆解系列专题 这一篇我们开始讲&#xff1a; Camera相机人脸识别系列专题分析之一&#xff1a;人脸识别系列专题SOP及理论知识…

【Elasticsearch】PUT` 请求覆盖式更新

是的&#xff0c;Elasticsearch 中的 PUT 请求是覆盖式的。当你使用 PUT 请求向索引中写入文档时&#xff0c;如果文档已经存在&#xff0c;Elasticsearch 会完全替换整个文档的内容&#xff0c;而不是进行部分更新。 覆盖式的具体行为 - 文档存在时&#xff1a;PUT 请求会用新…

计算机系统结构-第4章-数据级并行

数据集并行的概念: 并行场景1: 对不同数据执行相同的操作: 串行执行: 可以同时进行: 可以尝试一个多条指令,多核执行 引入: SISD: 单核,单线程,串行执行,这样耗时 MIMD: 多核,多线程,并行执行,一条指令多次重复,变成了MIMID 存在的问题: 在标量CPU流水线中&#xff0…

重新安装解决mac vscode点击不能跳转问题

依次执行以下过程 删除vscode程序 删除vscode的缓存文件夹(xxx表示你的用户名) /Users/xxx/Library/Application Support/Code 重新安装vscode 这时候你会反向可以跳转项目内的import 文件以及自定义函数。但是import安装的包还不能点击跳转 配置python环境 如果你电脑没有安…

题目 3334: 蓝桥杯2025年第十六届省赛真题-园艺

题目 3334: 蓝桥杯2025年第十六届省赛真题-园艺 时间限制: 2s 内存限制: 192MB 提交: 129 解决: 37 题目描述 小蓝从左到右种了 n 棵小树&#xff0c;第 i 棵树的高度为 hi &#xff0c;相邻树的间隔相同。 小蓝想挪走一些树使得剩下的树等间隔分布&#xff0c;且从左到右高度逐…

Chrome 开发中的任务调度与线程模型实战指南

内容 概述 快速入门指南 核心概念线程词典 线程任务优先使用序列而不是物理线程 发布并行任务 直接发布到线程池通过 TaskRunner 发布 发布顺序任务 发布到新序列发布到当前&#xff08;虚拟&#xff09;主题 使用序列代替锁将多个任务发布到同一线程 发布到浏览器进程中的主线…

详解osgb的顶点,纹理,索引,UV读取与存储

virtual void apply(osg::Geode& node) {for (int i 0; i < node.getNumDrawables(); i){osg::Geometry* geometry dynamic_cast<osg::Geometry*>(node.getDrawable(i));if (geometry){//apply(*g);//***********************************************//解析顶点…