python与flask框架
一、理论
Flask是一个轻量级的web框架,灵活易用。提供构建web应用所需的核心工具。
Flask依赖python的两个库
Werkzeug:flask的底层库,提供了WSGI接口、HTTP请求和响应处理、路由等核心功能。
Jinja2:模板引擎,用于动态生成HTML页面。
二、实践
1、第一个flask应用
[root@localhost ~]# pip config set global.index-url http://mirrors.aliyun.com/pypi/simple
Writing to /root/.config/pip/pip.conf
[root@localhost ~]# pip3 config set global.index-url http://mirrors.aliyun.com/pypi/simple
Writing to /root/.config/pip/pip.conf
[root@localhost ~]# pip3 config set install.trusted-host mirrors.aliyun.com
Writing to /root/.config/pip/pip.conf
[root@localhost ~]# pip3 install --upgrade pip[root@localhost ~]# pip install flask[root@localhost ~]# vim a.py
from flask import Flask# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/') # 用户的访问url为根时,flask会调用hello_world()函数。
def hello_world():return 'Hello,World!'# 启动应用
if __name__ == '__main__': # 该行用于确认当前脚本是否是通过命令行直接运行的,而不是作为其他模块或程序的一部分被导入的。app.run(host='0.0.0.0',port='5000',debug=True) # 启动flask开发服务器,debug=true表示启用调试模式,可在开发过程中自动重载应用,并在发生错误时显示详细信息。 host指定监听的地址,这里监听本机所有可用的地址,port指定监听的端口。[root@localhost ~]# python3 a.py # 运行该服务。* Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242[root@localhost ~]# firewall-cmd --add-port=5000/tcp # 开放端口
success [root@localhost ~]# curl 192.168.10.101:5000
Hello,World![root@localhost ~]# # 这里会这样显示是因为return的末尾未加\n(换行),所以导致这样显示。(命令行中输入完命令在末尾默认会加上换行,所以不会出现这种情况。)修改代码from flask import Flask# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/')
def hello_world():return 'Hello,World!\n' # 加上换行符即可。# 启动应用
if __name__ == '__main__':app.run(host='0.0.0.0',port='5000',debug=True)[root@localhost ~]# curl 192.168.10.101:5000
Hello,World!
[root@localhost ~]# c^C[root@localhost ~]# vim a.py
[root@localhost ~]# python3 a.py* Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242
192.168.10.101 - - [21/Apr/2025 09:08:50] "GET / HTTP/1.1" 200 -
192.168.10.101 - - [21/Apr/2025 09:08:53] "GET / HTTP/1.1" 200 -2、flask路由与视图函数
flask通过装饰器@app.route()来定义路由,而视图函数则负责处理用户的请求并返回响应。[root@localhost ~]# vim a.py
from flask import Flask# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/')
def hello_world():return 'Hello,World!\n'@app.route('/greet/<name>') # 这里定义了路径ip/greet/<name> 如果输入1,参数1会传递到下面的return中,会显示hello,1.
def greet(name):return f'Hello,{name}!\n' # f是用于字符串格式化,将输出结果显示为字符串。# 启动应用
if __name__ == '__main__':app.run(host='0.0.0.0',port='5000',debug=True)[root@localhost ~]# python3 a.py* Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242
192.168.10.101 - - [21/Apr/2025 09:14:38] "GET /greet/1 HTTP/1.1" 200 -[root@localhost ~]# curl 192.168.10.101:5000/greet/1
Hello,1!注意,这里只能这样写,写为192.168.10.101/greet/1:5000会失败,它会去找80端口。因为url的格式就是这样,平时访问网页,就是ip:port只不过port被隐藏了(因为是80,443常用端口,不需要写)。[root@localhost ~]# curl 192.168.10.101/greet/1:5000
curl: (7) Failed to connect to 192.168.10.101 port 80 after 0 ms: Couldn't connect to serverURL的组成部分:协议(protocol):指定了资源应该使用的访问方式,常见的协议有http、https、ftp等主机名(hostname):资源所在的服务器地址,可以是ip地址或域名。端口号(port):服务器上用于访问资源的技术接口。路径(path):资源在服务器上的具体位置。参数(parameters):提供给服务器的额外信息,通常以键值对的形式出现。查询(query):通过?与url的其他部分分隔,用于提供额外的请求信息。片段(fragment):通常以#开始,指向资源内部的一个锚点,如网页中的一个特定部分。url完整格式 http://www.hostname.com:80/index.html?lang=zh#contenthttp是协议,www.hostname.com是主机名,80是端口,/index.html是路径,lang=zh是查询参数,content是片段标识符。3、指定允许的请求方法。
[root@localhost ~]# vim a.py
from flask import Flask# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/')
def hello_world():return 'Hello,World!\n'@app.route('/greet/<name>')
def greet(name):return f'Hello,{name}!\n'@app.route('/submit',methods=['POST'])
def submit():return 'Form submitted successfully!\n' # Form是html里定义请求方式时用到的关键字。# 启动应用
if __name__ == '__main__':app.run(host='0.0.0.0',port='5000',debug=True) [root@localhost ~]# python3 a.py * Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242[root@localhost ~]# curl 192.168.10.101:5000/submit
<!doctype html>
<html lang=en>
<title>405 Method Not Allowed</title>
<h1>Method Not Allowed</h1>
<p>The method is not allowed for the requested URL.</p>
[root@localhost ~]# curl -XPOST 192.168.10.101:5000/submit
Form submitted successfully!4、使用jinja2模板渲染html[root@localhost ~]# mkdir templates
[root@localhost ~]# ls
anaconda-ks.cfg a.py templates # 模板文件与主程序(a.py必须在同一级目录下,否则会找不到,名称也必须叫templates,否则也会找不到。)
[root@localhost ~]# cd templates/
[root@localhost templates]# vim greet.html
<html lang="en">
<head><meta charset="UTF-8"><title>Flask Example</title>
</head>
<body><h1>Hello,{{ name }}!<h1> # {{ }} 这种格式是jinja2模板格式。name同样是参数传递,ip/greet/name中的name会传递到这里。
</body>
</html>[root@localhost ~]# vim a.py
from flask import Flask
from flask import render_template# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/')
def hello_world():return 'Hello,World!\n'@app.route('/submit',methods=['POST'])
def submit():return 'Form submitted successfully!\n'@app.route('/greet/<name>')
def greet(name):return render_template('greet.html',name=name)# 启动应用
if __name__ == '__main__':[root@localhost ~]# python3 a.py* Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242[root@localhost ~]# curl 192.168.10.101:5000/greet/aaa
<html lang="en">
<head> <meta charset="UTF-8"><title>Flask Example</title>
</head>
<body><h1>Hello,aaa!<h1>
</body>4、模板继承与块[root@localhost ~]# ls
anaconda-ks.cfg a.py templates
[root@localhost ~]# cat a.py
from flask import Flask
from flask import render_template# 创建Flask应用实例
app=Flask(__name__)# 定义路由和视图函数
@app.route('/')
def hello_world():return 'Hello,World!\n'@app.route('/submit',methods=['POST'])
def submit():return 'Form submitted successfully!\n'@app.route('/index')
def index():return render_template('index.html')# 启动应用
if __name__ == '__main__':app.run(host='0.0.0.0',port='5000',debug=True)[root@localhost ~]# cd templates/
[root@localhost templates]# ls
base.html greet.html index.html
[root@localhost templates]# cat base.html
<html lang="en">
<head><meta charset="UTF-8"><title>{% block title %}My Website{% endblock %}</title> # 定义块开始与结束位置,并定义其中的内容。子模板引用父模板就是通过块来引用的。
</head>
<body><header><h1>Welcome to My Website</h1></header><div> # div是html里的块级元素,属于容器,可包含标题、段落、表格等等。{% block content %}{% endblock %} # 定义块开始与结束,content是内容。</div><footer><p>© 2025 My Website</p> # 页脚处的信息。</footer>
</body>
</html>
[root@localhost templates]# cat index.html
{% extends 'base.html' %}{% block title %}Home{% endblock %} # 网站标签处的显示信息。例如百度的,百度一下,你就知道。{% block content %}<h2> Welcome to the homepage !</h2>###
{% extends 'base.html' %} 子模版继承了base.html模板。
{% block title %}Home {% endblock %} 覆盖父模板中的title块。
{% block content %} 定义页面的主要内容区域。[root@localhost ~]# python3 a.py* Serving Flask app 'a'* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.* Running on all addresses (0.0.0.0)* Running on http://127.0.0.1:5000* Running on http://192.168.10.101:5000
Press CTRL+C to quit* Restarting with stat* Debugger is active!* Debugger PIN: 112-870-242[root@localhost ~]# curl 192.168.10.101:5000/index
<html lang="en">
<head><meta charset="UTF-8"><title>Home</title>
</head>
<body><header><h1>Welcome to My Website</h1></header><div><h2> Welcome to the homepage !</h2></div><footer><p>© 2025 My Website</p></footer>
</body>
相关文章:
python与flask框架
一、理论 Flask是一个轻量级的web框架,灵活易用。提供构建web应用所需的核心工具。 Flask依赖python的两个库 Werkzeug:flask的底层库,提供了WSGI接口、HTTP请求和响应处理、路由等核心功能。 Jinja2:模板引擎࿰…...
【普及+/提高】洛谷P2613 【模板】有理数取余——快读+快速幂
题目来源 P2613 【模板】有理数取余 - 洛谷 题目描述 给出一个有理数 cba,求 cmod19260817 的值。 这个值被定义为 bx≡a(mod19260817) 的解。 输入格式 一共两行。 第一行,一个整数 a。 第二行,一个整数 b。 输出格式 一个整数&a…...

从数据到智能:openGauss+openEuler Intelligence的RAG架构实战
随着人工智能和大规模语言模型技术的崛起,传统的搜索引擎由于其只能提供简单的关键字匹配结果,已经越来越无法满足用户对于复杂、多样化和上下文相关的知识检索需求。与此相对,RAG(Retrieval-Augmented Generation)技术…...

【Linux】初见,基础指令
前言 本文将讲解Linux中最基础的东西-----指令,带大家了解一下Linux中有哪些基础指令,分别有什么作用。 本文中的指令和选项并不全,只介绍较为常用的 pwd指令 语法:pwd 功能:显示当前所在位置(路径…...

什么是实时流数据?核心概念与应用场景解析
在当今数字经济时代,实时流数据正成为企业核心竞争力。金融机构需要实时风控系统在欺诈交易发生的瞬间进行拦截;电商平台需要根据用户实时行为提供个性化推荐;工业物联网需要监控设备状态预防故障。这些场景都要求系统能够“即时感知、即时分…...

工业RTOS生态重构:从PLC到“端 - 边 - 云”协同调度
一、引言 在当今数字化浪潮席卷全球的背景下,工业领域正经历着深刻变革。工业自动化作为制造业发展的基石,其技术架构的演进直接关系到生产效率、产品质量以及企业的市场竞争力。传统的PLC(可编程逻辑控制器)架构虽然在工业控制领…...
数据结构与算法学习笔记(Acwing 提高课)----动态规划·状态机模型
数据结构与算法学习笔记----动态规划状态机模型 author: 明月清了个风 first publish time: 2025.5.20 ps⭐️背包终于结束了,状态机模型题目不多。状态机其实是一种另类的状态表示方法,将某一个点扩展为一个状态进行保存并在多个状态之间转移…...

基于开源链动2+1模式AI智能名片S2B2C商城小程序的社群构建与新型消费迎合策略研究
摘要:随着个性化与小众化消费的崛起,消费者消费心理和模式发生巨大变化,社群构建对商家迎合新型消费特点、融入市场经济发展至关重要。开源链动21模式AI智能名片S2B2C商城小程序的出现,为社群构建提供了创新工具。本文探讨该小程序…...

高性能RPC框架--Dubbo(五)
Filter: filter过滤器动态拦截请求(request)或响应(response)以转换或使用请求或响应中包含的信息。同时对于filter过滤器不仅适合消费端而且还适合服务提供端。我们可以自定义在什么情况下去使用filter过滤器 Activa…...
计算机视觉与深度学习 | PSO-MVMD粒子群算法优化多元变分模态分解(Matlab完整代码和数据)
以下是一个基于PSO优化多元变分模态分解(MVMD)的Matlab示例代码框架,包含模拟数据生成和分解结果可视化。用户可根据实际需求调整参数。 %% 主程序:PSO优化MVMD参数 clc; clear; close all;% 生成模拟多变量信号 fs = 1000; % 采样频率 t = 0:1/fs:...

搭建自己的语音对话系统:开源 S2S 流水线深度解析与实战
网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…...

feign调用指定服务ip端口
1 背景 在springcloud开发时候,同时修改了feign接口和调用方的代码,希望直接在某个环境调用修改的代码,而线上的服务又不希望被下线因为需要继续为其他访问页面的用户提供功能后端服务,有时候甚者包含你正在修改的功能。 2 修改…...

【深尚想!爱普特APT32F1023H8S6单片机重构智能电机控制新标杆】
在智能家电与健康器械市场爆发的今天,核心驱动技术正成为产品突围的关键。传统电机控制方案面临集成度低、开发周期长、性能瓶颈三大痛点,而爱普特电子带来的APT32F1023H8S6单片机无感三合一方案,正在掀起一场智能电机控制的技术革命。 爆款基…...
vue2 中的过滤器以及vue3中的替换方案
在 Vue 2 中,过滤器(filters) 是一种非常实用的语法糖,用于在模板中对数据进行格式化输出处理。我们来深入理解过滤器的原理、使用方式、最佳实践以及其局限性。 vue2 🧠 本质是什么? Vue 2 的过滤器是一…...

Unity EventCenter 消息中心的设计与实现
在开发过程中,想要传递信号和数据,就得在不同模块之间实现通信。直接通过单例调用虽然简单,但会导致代码高度耦合,难以维护。消息中心提供了一种松耦合的通信方式:发布者不需要知道谁接收事件,接收者不需要…...
瑞萨单片机笔记
1.CS for CC map文件中显示变量地址 Link Option->List->Output Symbol information 2.FDL库函数 pfdl_status_t R_FDL_Write(pfdl_u16 index, __near pfdl_u08* buffer, pfdl_u16 bytecount) pfdl_status_t R_FDL_Read(pfdl_u16 index, __near pfdl_u08* buffer, pfdl_…...
300. 最长递增子序列【 力扣(LeetCode) 】
文章目录 零、原题链接一、题目描述二、测试用例三、解题思路3.1 动态规划3.2 贪心 二分 四、参考代码4.1 动态规划4.2 贪心 二分 零、原题链接 300. 最长递增子序列 一、题目描述 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组…...

MySQL远程连接10060错误:防火墙端口设置指南
问题描述: 如果你通过本机服务器远程连接MySQL,出现10060错误,那可能是你的防火墙的问题 解决: 第一步:查看防火墙规则 通过以下命令查询,看ports是否开放了3306端口,目前只开放了22端口 f…...

使用 OpenCV 实现 ArUco 码识别与坐标轴绘制
🎯 使用 OpenCV 实现 ArUco 码识别与坐标轴绘制(含Python源码) Aruco 是一种广泛用于机器人、增强现实(AR)和相机标定的方形标记系统。本文将带你一步一步使用 Python OpenCV 实现图像中多个 ArUco 码的检测与坐标轴…...
2024CCPC辽宁省赛 个人补题 ABCEGJL
Dashboard - 2024 CCPC Liaoning Provincial Contest - Codeforces 过题难度 B A J C L E G 铜奖 4 953 银奖 6 991 金奖 8 1664 B: 模拟题 // Code Start Here string s;cin >> s;reverse(all(s));cout << s << endl;A:很…...
#6 百日计划第六天 java全栈学习
今天学的啥 上午 算法byd图论 图遍历dfs bfs 没学懂呵呵 找到两个良心up 图码 labuladong 看算法还好 尚硅谷讲的太浅了 那你问我 下午呢 下午 java 看了会廖雪峰的教程 回顾基础 小林coding Java基础八股文 还有集合的八股文 有的不是很懂 今天把Java基础算是完…...
AOP的代理模式
AOP的代理模式 1. AOP的实现方式 Spring AOP 主要通过两种动态代理技术实现: JDK动态代理:基于接口的代理,要求目标类必须实现至少一个接口。通过反射机制在运行时生成代理类(实现目标接口),并重写接口…...
解决leetcode第3548题.等和矩阵分割II
3548.等和矩阵分割II 难度:困难 问题描述: 给你一个由正整数组成的mxn矩阵grid。你的任务是判断是否可以通过一条水平或一条垂直分割线将矩阵分割成两部分,使得: 分割后形成的每个部分都是非空的。 两个部分中所有元素的和相…...
深入解析自然语言处理中的语言转换方法
在数字化浪潮席卷全球的今天,自然语言处理(Natural Language Processing,NLP)作为人工智能领域的核心技术之一,正深刻地改变着我们与机器交互的方式。其中,语言转换方法更是 NLP 的关键组成部分,…...
redis 进行缓存实战-18
使用 Redis 进行缓存 Redis 通常被认为只是一个数据存储,但它的速度和内存中特性使其成为缓存的绝佳选择。缓存是一种技术,通过将经常访问的数据存储在快速的临时存储位置来提高应用程序性能。通过使用 Redis 作为缓存,您可以显著减少主数据…...
JFace中MVC的表的单元格编辑功能的实现
一、实现流程 在JFace中实现MVC模式的表格编辑功能通常需要以下步骤: 1、启用编辑模式: 调用TableVierer对象的setCellModifier()方法,设置一个ICellModifier对象,以便在表格中启用编辑模式。实现ICellModifier接口的canModify(…...
在 Excel xll 自动注册操作 中使用东方仙盟软件2————仙盟创梦IDE
// 获取当前工作表名称string sheetName (string)XlCall.Excel(XlCall.xlfGetDocument, 7);// 构造动态名称(例如:Sheet1!MyNamedCell)string fullName $"{sheetName}!MyNamedCell";// 获取引用并设置值var namedRange (ExcelRe…...

canal实现mysql数据同步
目录 1、canal下载 2、mysql同步用户创建和授权 3、canal admin安装和启动 4、canal server安装和启动 5、java 端集成监听canal 同步的mysql数据 6、java tcp同步只是其中一种方式,还可以通过kafka、rabbitmq等方式进行数据同步 1、canal下载 canal实现mysq…...
解决 MySQL 表结构修改中锁定异常的全链路实战指南:从表结构设计到版本调优
引言 在 MySQL 中执行ALTER TABLE修改表结构(如新增字段、调整字段类型)时,锁定异常是最常见的阻碍。无论是 5.7 的 “锁等待超时”、8.0 的 “MDL 锁阻塞”,还是高并发下的 “长事务死锁”,本质都是表结构修改需要获…...
动态规划应用场景 + 代表题目清单(模板加上套路加上题单)
1. 序列型DP(Sequence DP) ✅ 应用场景 单个或多个序列(数组/字符串),求最优子结构。 常见问题:最长递增子序列、最长公共子序列、回文子序列。 🧠 套路总结 单序列:dp[i] max(…...