第一个 Flask 项目

第一个 Flask 项目

  • 安装环境
  • 创建项目
  • 启动程序
  • 访问项目
  • 参数说明
    • Flask对象的初始化参数
    • app.run()参数
  • 应用程序配置参数
    • 使用 Flask 的 `config.from_object()` 方法
    • 使用 Flask 的 `config.from_pyfile()` 方法
    • 使用 Flask 的 `config.from_envvar()` 方法
      • 步骤 1: 设置环境变量
      • 步骤 2: 编写配置文件
      • 步骤 3: 在 Flask 应用中使用 `config.from_envvar()`
    • 4. 使用 Flask-AppConfig 或其他扩展
    • 结论

安装环境

mkvirtualenv flask_envpip install flask

创建项目

在这里插入图片描述

启动程序

在这里插入图片描述

访问项目

在这里插入图片描述

http://127.0.0.1:5000/
在这里插入图片描述

参数说明

Flask是一个用Python编写的轻量级Web应用框架,它提供了构建Web应用所需的基本工具和功能。以下是Flask的一些主要参数说明:

Flask对象的初始化参数

在创建Flask应用时,可以通过Flask类的构造函数传递一些参数来定制应用的行为。
在这里插入图片描述

Flask对象的初始化是通过调用Flask类并传递参数来完成的。虽然Flask类提供了许多参数,但大多数情况下,你只需要关注其中的几个关键参数。下面是对Flask类初始化时常用和可能用到的参数的详细解释:

  1. import_name: 这是Flask应用所在的包或模块的名称。Flask使用这个参数来定位应用相对于其他资源的路径(如模板和静态文件)。在大多数情况下,你可以直接传递__name__作为这个参数的值。

  2. static_folder: 这是一个可选参数,用于指定静态文件(如CSS、JS、图片等)的文件夹路径。默认情况下,它会被设置为'<yourapplication>/static'

  3. static_url_path: 这也是一个可选参数,用于指定静态文件在Web上访问的URL路径。默认情况下,它会与static_folder的参数值相同,即'/static'

  4. template_folder: 这是一个可选参数,用于指定模板文件的文件夹路径。默认情况下,它会被设置为'<yourapplication>/templates'

  5. instance_path: Flask应用实例的文件夹路径,用于存放应用的一些临时文件(如上传的文件)。默认情况下,它会被设置为'<yourapplication>/instance'。但请注意,这个路径是相对于import_name指定的包或模块的路径的。

  6. instance_relative_config: 这是一个布尔值参数,用于指定配置文件是否应该相对于实例文件夹(由instance_path指定)加载。默认为False,意味着配置文件应该位于应用的根目录或指定的绝对路径。

  7. root_path: Flask应用的根目录。在大多数情况下,你不需要手动设置这个参数,因为Flask会根据import_name自动推断出根目录。

  8. url_map_class: 用于创建URL映射的类的名称。这通常用于自定义URL解析的行为。大多数情况下,你可以忽略这个参数。

  9. subdomain_matching: 一个布尔值,用于控制是否应该启用子域匹配。这在构建需要基于子域进行路由的复杂应用时非常有用。

  10. template_context_processors: 一个列表,包含用于向模板上下文添加额外变量的函数。这些函数会在模板渲染之前被调用。

  11. cli_class: 用于自定义Flask CLI的类。Flask CLI是一个强大的命令行界面,用于执行各种与Flask应用相关的任务。

  12. cli_group: 用于将自定义命令分组到特定的Flask CLI子命令中的名称。

  13. server_name: 服务器名称的字符串,用于辅助URL生成和子域支持。这通常只在需要知道应用的确切URL前缀时才会用到。

  14. application_factory: Flask 1.1.0中引入的,一个布尔值,指示应用工厂模式是否被使用。这通常用于与WSGI服务器和扩展交互,以支持延迟创建应用实例。

请注意,虽然这里列出了许多参数,但在日常开发中,你通常只需要关注import_namestatic_folderstatic_url_pathtemplate_folder等少数几个参数。其他参数主要用于更高级或特定的用例。

另外,值得注意的是,Flask的run()方法(用于启动开发服务器)也接受一些参数,如hostportdebug等,但这些参数与Flask对象的初始化无关,而是与启动开发服务器时的配置有关。

app.run()参数

在这里插入图片描述

app.run() 方法在 Flask 中用于启动开发服务器。虽然对于大多数基本用途,你可能只需要设置 debughostport 几个参数,但 run() 方法实际上提供了更多的配置选项。以下是 app.run() 方法的一些常用和可能的参数解释:

  1. host: 监听的主机名。默认为 127.0.0.1,即服务器仅接收来自运行它的机器的连接。如果你想要你的应用可以从网络上的任何位置被访问,可以设置为 '0.0.0.0'

  2. port: 监听的端口号。默认为 5000。端口号是一个 0 到 65535 之间的整数,用于区分运行在同一台机器上的不同服务。

  3. debug: 是否启用 Flask 的调试模式。默认为 False。在调试模式下,Flask 会提供更多关于错误的详细信息,并且允许你在不重启服务器的情况下修改代码并查看更改效果(使用某些开发工具时)。但请注意,在生产环境中应该关闭调试模式,因为它会暴露敏感信息。

  4. threaded: 是否使用多线程。默认为 False。如果你的应用需要处理多个并发请求,可以启用此选项。然而,在生产环境中,通常建议使用像 Gunicorn 这样的 WSGI 服务器来处理并发,因为它们提供了更好的性能和配置选项。

  5. processes: 如果 threadedFalse,则这个参数指定启动的进程数。默认为 1。这通常用于在 Unix 系统上,通过多进程而不是多线程来利用多核 CPU。但是,请注意,这与 threaded 参数是互斥的;你不能同时设置 threaded=Trueprocesses>1

  6. passthrough_errors: 当设置为 True 时,错误会通过 HTTP 状态码传播。这主要用于调试目的,并允许错误处理程序(如果有的话)处理它们。默认为 False

  7. ssl_context: 一个包含 SSL 证书的元组 (certificate, key),用于启用 HTTPS。这对于保护你的应用和用户数据非常重要。如果没有提供,服务器将默认使用 HTTP。

  8. use_reloader: 是否使用 Flask 的代码重新加载器。在调试模式下,这通常是启用的,但你可以通过将此参数设置为 False 来禁用它。注意,这可能会因 Flask 版本而异,因为某些版本可能直接通过 debug 参数控制代码重新加载。

  9. use_debugger: 是否启用 Flask 的交互式调试器。这允许你在出现未捕获的异常时获得一个交互式调试会话。默认为 Truedebug=True 时,但你可以通过将此参数设置为 False 来禁用它。

  10. use_evalex: 是否在调试器的代码执行环境中启用 evalex(一个可以执行任意 Python 代码的交互式 shell)。出于安全考虑,默认为 Truedebug 未被显式设置或 debug=True 时,但你可以通过将此参数设置为 False 来禁用它。

请注意,这些参数可能会随着 Flask 版本的更新而发生变化。因此,建议查阅你正在使用的 Flask 版本的官方文档以获取最准确的信息。

应用程序配置参数

在 Flask 应用程序中,配置参数是管理和定制应用行为的关键部分。Flask 提供了一种灵活的方式来加载和配置这些参数。以下是一些常用的方法来加载 Flask 应用程序的配置参数:
在 Flask 应用程序中加载配置参数是一个常见的需求,它允许你根据应用程序的不同环境(如开发、测试和生产)来调整其行为。以下是一些在 Flask 应用程序中加载配置参数的方法:

使用 Flask 的 config.from_object() 方法

你可以定义一个或多个配置类(通常是在一个单独的 Python 文件中),然后在 Flask 应用初始化时通过 config.from_object() 方法加载这些配置。

config.py

class Config:DEBUG = FalseTESTING = FalseSECRET_KEY = 'a_very_secret_key'class DevelopmentConfig(Config):DEBUG = Trueclass TestingConfig(Config):TESTING = Trueclass ProductionConfig(Config):DEBUG = False

app.py

from flask import Flask
from config import DevelopmentConfigapp = Flask(__name__)
app.config.from_object(DevelopmentConfig)# 现在 app.config 包含了 DevelopmentConfig 中的配置

使用 Flask 的 config.from_pyfile() 方法

如果你更喜欢使用配置文件(如 .ini.cfg.py 文件,但不带类),你可以使用 config.from_pyfile() 方法。

config.py

DEBUG = True
SECRET_KEY = 'a_very_secret_key'

app.py

from flask import Flaskapp = Flask(__name__)
app.config.from_pyfile('config.py')# 现在 app.config 包含了 config.py 文件中的配置

注意:如果 config.py 文件不在 Flask 应用的根目录下,你需要提供完整的路径。

使用 Flask 的 config.from_envvar() 方法

Flask 的 config.from_envvar() 方法允许你根据环境变量中指定的文件名来加载配置。这种方法特别有用于当你想要根据环境(如开发、测试、生产)动态地选择配置文件时。

首先,你需要在环境变量中设置一个值,该值指向你的配置文件(例如,一个 .py 文件或 .ini 文件,但请注意 Flask 原生只支持 .py 文件或可以被解析为 Python 字典的 .json 文件)。然后,在 Flask 应用初始化时,使用 config.from_envvar() 方法并传入环境变量的名称。

步骤 1: 设置环境变量

在 Unix-like 系统中,你可以在 shell 配置文件(如 .bashrc.bash_profile)中设置环境变量:

export FLASK_CONFIG_FILE=/path/to/your/config.py

在 Windows 系统中,你可以在命令提示符或 PowerShell 中设置环境变量:

set FLASK_CONFIG_FILE=C:\path\to\your\config.py

或者使用 PowerShell:

$env:FLASK_CONFIG_FILE="C:\path\to\your\config.py"

步骤 2: 编写配置文件

假设你的配置文件是一个 Python 文件(config.py),它看起来像这样:

# config.py
DEBUG = True
SECRET_KEY = 'a_very_secret_key'
# 其他配置...

步骤 3: 在 Flask 应用中使用 config.from_envvar()

在你的 Flask 应用中,使用 config.from_envvar() 方法来加载配置:

from flask import Flaskapp = Flask(__name__)
app.config.from_envvar('FLASK_CONFIG_FILE')# 现在 app.config 包含了 config.py 文件中的配置

然而,需要注意的是,config.from_envvar() 方法实际上期望环境变量指向一个 Python 文件(或可以解析为 Python 字典的 JSON 文件),并且该文件应该定义了一个 Python 字典或类似字典的对象(通常是通过定义一个或多个配置类来实现的),但在这个例子中,我们直接使用了 Python 文件。

如果你的环境变量指向的是一个 .ini 文件或其他非 Python 文件,并且你希望 Flask 能够加载它,你可能需要使用一个自定义的加载函数或 Flask 扩展(如 Flask-AppConfig,尽管它可能不直接使用 from_envvar() 方法)。

但是,对于 .ini 文件,Flask 没有直接的支持,因此你可能需要编写一些额外的代码来解析这个文件,并将其内容设置为 Flask 的配置。

对于 .json 文件,你可以使用 config.from_json() 方法,但同样,你需要先以某种方式(如通过环境变量)获取到 .json 文件的路径。不过,这通常不是通过 from_envvar() 方法直接完成的,因为 from_envvar() 预期的是一个指向 Python 配置文件的路径。

4. 使用 Flask-AppConfig 或其他扩展

虽然 Flask 核心本身提供了基本的配置加载功能,但你也可以使用 Flask 扩展(如 Flask-AppConfig)来简化配置加载过程。这些扩展通常提供了更灵活的配置加载选项,包括从多个源加载配置的能力。

结论

选择哪种方法取决于你的具体需求和环境。对于大多数项目,结合使用配置类和环境变量是一种灵活且强大的方法。这样,你可以轻松地根据不同的环境调整配置,而无需修改代码或配置文件。

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

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

相关文章

【C++学习第19天】最小生成树(对应无向图)

一、最小生成树 二、代码 1、Prim算法 #include <cstring> #include <iostream> #include <algorithm>using namespace std;const int N 510, INF 0x3f3f3f3f;int n, m; int g[N][N]; int dist[N]; bool st[N];int prim() {memset(dist, 0x3f, sizeof di…

学习分享:解析电商 API 接入的技术重难点及解决方案

在当今电商业务迅速发展的时代&#xff0c;接入电商 API 已成为许多企业提升竞争力和拓展业务的重要手段。然而&#xff0c;在这个过程中&#xff0c;往往会遇到一系列的技术重难点。本文将深入解析这些问题&#xff0c;并提供相应的解决方案。 一、电商 API 接入的技术重难点 …

c++ 初始值设定项列表(initializer_list)

引例 我们在写c代码的时候&#xff0c;多多少少会遇到这样写的&#xff1a; 如果是这样写还好说&#xff1a; 第一个是因为编译器强制匹配参数。 其他都是因为在有对应构造函数的情况下支持的隐式类型转换。 而支持的构造函数是这个&#xff1a; 如果有不懂的可以开这一篇&a…

麦田物语第十八天

系列文章目录 麦田物语第十八天 文章目录 系列文章目录一、(Editor)制作 [SceneName] Attribute 特性二、场景切换淡入淡出和动态 UI 显示一、(Editor)制作 [SceneName] Attribute 特性 在本节课我们编写Unity的特性Attribute来更好的完善我们项目,具体是什么呢,就是当…

深入理解 ReLU 激活函数及其在深度学习中的应用【激活函数、Sigmoid、Tanh】

ReLU&#xff08;Rectified Linear Unit&#xff09;激活函数 ReLU&#xff08;Rectified Linear Unit&#xff09;激活函数是一种广泛应用于神经网络中的非线性激活函数。其公式如下&#xff1a; ReLU ( x ) max ⁡ ( 0 , x ) \text{ReLU}(x) \max(0, x) ReLU(x)max(0,x) 在…

docker部署elasticsearch和Kibana

部署elasticsearch 通过下面的Docker命令即可安装单机版本的elasticsearch&#xff1a; docker run -d \--name es \-e "ES_JAVA_OPTS-Xms512m -Xmx512m" \-e "discovery.typesingle-node" \-v es-data:/usr/share/elasticsearch/data \-v es-plugins:/u…

《LeetCode热题100》---<5.①普通数组篇五道>

本篇博客讲解LeetCode热题100道普通数组篇中的五道题 第一道&#xff1a;最大子数组和&#xff08;中等&#xff09; 第二道&#xff1a;合并区间&#xff08;中等&#xff09; 第一道&#xff1a;最大子数组和&#xff08;中等&#xff09; 法一&#xff1a;贪心算法 class So…

我的256天创作纪念日

机缘 ————今天一大早收到CSDN的推送消息&#xff0c;告诉我这是我的256天创作纪念日。在这个特别的日子里&#xff0c;我回望自己踏上创作之路的点点滴滴&#xff0c;心中充满了感慨与感激。从最初的懵懂尝试到如今能够自信地分享见解&#xff0c;这段旅程不仅见证了我的成…

【教学类-73-01】20240804镂空瓶子01

背景需求&#xff1a; 瓶子里的春天呀&#xff01; - 小红书 (xiaohongshu.com)https://www.xiaohongshu.com/explore/63ef87f8000000000703acae?app_platformandroid&ignoreEngagetrue&app_version8.47.0&share_from_user_hiddentrue&xsec_sourceapp_share&…

揭秘Matplotlib等高线图:让数据‘高山流水‘间,笑点与深度并存!

1. 引言 在这个数据如山的时代&#xff0c;你是不是也曾在茫茫数海中迷失方向&#xff0c;渴望找到那片隐藏的“数据绿洲”&#xff1f;别怕&#xff0c;今天咱们就来聊聊Matplotlib这位绘图界的魔术师&#xff0c;特别是它那令人叹为观止的等高线图技能。想象一下&#xff0c…

MySQL:数据库用户

数据库用户 在关系型数据库管理系统中&#xff0c;数据库用户&#xff08;USER&#xff09;是指具有特定权限和访问权限的登录账户。每个用户都有自己的用户名和密码&#xff0c;以便系统可以通过认证来识别他们的身份。数据库用户可以登录数据库&#xff0c;在其中执行各种类…

【QT】常用控件-上

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;折纸花满衣 目录 &#x1f449;&#x1f3fb;QWidgetenabledgeometryrect制作上下左右按钮 window frame 的影响window titlewindowIcon代码示例: 通过 qrc 管理图片作为图标 windowOpacitycursor使用qrc自…

【论文笔记】SEED: A Simple and Effective 3D DETR in Point Clouds

原文链接&#xff1a;https://arxiv.org/abs/2407.10749 简介&#xff1a;基于DETR的3D点云检测器难以达到较高的性能&#xff0c;这可能有两个原因&#xff1a;&#xff08;1&#xff09;由于点云的稀疏性和分布不均匀&#xff0c;获取合适的物体查询较为困难&#xff1b;&…

基于微信小程序的微课堂笔记的设计与实现(源码+论文+部署讲解等)

博主介绍&#xff1a;✌全网粉丝10W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术栈介绍&#xff1a;我是程序员阿龙&#xff…

给虚拟机Ubuntu扩展硬盘且不丢数据

1.Ubuntu关机状态下先扩展&#xff0c;如扩展20GB 2.进入ubuntu&#xff0c;切换root登录&#xff0c;必须是root全选&#xff0c;否则启动不了分区工具gparted 将新的20GB创建好后&#xff0c;选择ext4,primary&#xff1b; 3.永久挂载 我的主目录在/并挂载到/dev/sda1 从图…

【C++】C++11之新的类功能与可变参数模板

目录 一、新的默认成员函数 二、新的关键字 2.1 default 2.2 detele 2.3 final和override 三、可变参数模板 3.1 定义 3.2 递归展开参数包 3.3 逗号表达式展开参数包 3.4 emplace_back 一、新的默认成员函数 在C11之前&#xff0c;默认成员函数只有六个&#xff0c;…

【机器学习算法基础】(基础机器学习课程)-11-k-means-笔记

示例案例 为了更好地理解 K-Means 算法&#xff0c;下面通过一个简单的案例进行说明。 假设我们有以下 10 个二维数据点&#xff0c;表示不同商店的销售额&#xff08;单位&#xff1a;千元&#xff09;和顾客数&#xff08;单位&#xff1a;人&#xff09;&#xff1a; [(1…

常见cms漏洞之dedecms

DedeCMS是织梦团队开发PHP 网站管理系统&#xff0c;它以简单、易用、高效为特色&#xff0c;组建出各种各样各具特色的网站&#xff0c;如地方门户、行业门户、政府及企事业站点等。 下载地址请网上自行寻找 搭建方式选择php study 首先搭建环境 #前台http://localhost/dedecm…

Java AI伪原创视频创作视频提取文案改写去水印系统小程序源码

&#x1f525;AI赋能创作新纪元&#xff01;伪原创视频文案提取改写去水印全能系统大揭秘 &#x1f680; 开篇&#xff1a;创意无界&#xff0c;AI来助力 在这个视觉盛行的时代&#xff0c;视频创作成为了表达自我、传递信息的重要方式。但你是否曾为寻找灵感、撰写文案、处理…

sa-token登录机制以及网关统一鉴权环境搭建

文章目录 1.sa-token1.37集成&#xff08;基于token&#xff09;1.文档网址2.**sun-club-auth-application-controller引入依赖**3.application.yml4.sun-club-auth-application-controller测试的controller1.UserController.java2.启动测试1.登录&#xff0c;得到satoken2.验证…