Mi informacion de contacto
Correo[email protected]
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Marcos antiguos de uso común: django (admite asincrónico después de 3.0), flask (admite asincrónico después de 2.0), tornado (asincrónico), twisted (asincrónico)
Nuevos marcos de uso común: FastAPI, sanic, django4.0 (la versión actual está en proceso de transformación de síncrona a asíncrona), flask2.0 (la versión actual está en proceso de transformación de síncrona a asíncrona)
Sanic: https://sanicframework.org/zh/guide/
FastAPI: https://fastapi.tiangolo.com/zh/tutorial/first-steps/
Flask nació en 2010. Es un marco de desarrollo web liviano escrito por Armin Ronacher en lenguaje Python basado en la caja de herramientas Werkzeug.
Flask en sí es equivalente a un kernel, y casi todas las demás funciones requieren extensiones (extensión de correo electrónico Flask-Mail, autenticación de usuario Flask-Login, base de datos Flask-SQLAlchemy), todas las cuales deben implementarse con extensiones de terceros. Por ejemplo, puede usar la extensión Flask para agregar ORM, herramientas de verificación de formularios, carga de archivos, verificación de identidad, etc. Flask no utiliza una base de datos predeterminada. Puede elegir MySQL o NoSQL.
La caja de herramientas WSGI de Flask usa Werkzeug (módulo de enrutamiento) y el motor de plantillas usa Jinja2. Itsdangrous (módulo de cifrado de tokens), Click (herramienta de administración de comandos de terminal) y el propio kernel del flask, estos cinco módulos principales forman el marco de Flask.
Sitio web oficial: https://flask.palletsprojects.com/en/2.0.x/
Documentación oficial: https://dormousehole.readthedocs.io/es/latest/index.html
Paquetes de extensión de terceros de uso común para Flask:
Puede ver más extensiones recomendadas oficialmente por flask a través de https://pypi.org/search/?c=Framework+%3A%3A+Flask
# anaconda创建虚拟环境
conda create -n flask python=3.9
# 进入/切换到指定名称的虚拟环境,如果不带任何参数,则默认回到全局环境base中。
# conda activate <虚拟环境名称>
conda activate flask
# 退出当前虚拟环境
conda deactivate
Para instalar flask, use el siguiente comando:
pip install flask -i https://pypi.douban.com/simple
A diferencia de Django, Flask no proporciona ninguna operación automática, por lo que debe crear manualmente el directorio del proyecto y el archivo de administración para iniciar el proyecto.
Por ejemplo, cree el directorio del proyecto flaskdemo y cree Manage.py en el directorio. Abra el proyecto en pycharm y especifique el entorno virtual creado anteriormente.
Cree un archivo de entrada de inicio para el marco del matraz.El nombre puede serapp.py/run.py/main.py/index.py/manage.py/start.py
administrar.py, código:
# 1. 导入flask核心类
from flask import Flask
# 2. 初始化web应用程序的实例对象
app = Flask(__name__)
# 4. 可以通过实例对象app提供的route路由装饰器,绑定视图与uri地址的关系
@app.route("/")
def index():
# 5. 默认flask支持函数式视图,视图的函数名不能重复,否则报错!!!
# 视图的返回值将被flask包装成响应对象的HTML文档内容,返回给客户端。
return "<h1>hello flask</h1>"
if __name__ == '__main__':
# 3. 运行flask提供的测试web服务器程序
app.run(host="0.0.0.0", port=5000, debug=True)
Análisis de código:
# 导入Flask类
from flask import Flask
"""
Flask类的实例化参数:
import_name Flask程序所在的包(模块),传 __name__ 就可以
其可以决定 Flask 在访问静态文件时查找的路径
static_path 静态文件存储访问路径(不推荐使用,使用 static_url_path 代替)
static_url_path 静态文件的url访问路径,可以不传,默认为:/ + static_folder
static_folder 静态文件存储的文件夹,可以不传,默认为 static
template_folder 模板文件存储的文件夹,可以不传,默认为 templates
"""
app = Flask(__name__)
# 编写路由视图
# flask的路由是通过给视图添加装饰器的方式进行编写的。当然也可以分离到另一个文件中。
# flask的视图函数,flask中默认允许通过return返回html格式数据给客户端。
@app.route('/')
def index():
# 返回值如果是字符串,被自动作为参数传递给response对象进行实例化返回客户端
return "<h1>hello flask</h1>"
# 指定服务器IP和端口
if __name__ == '__main__':
# 运行flask
app.run(host="0.0.0.0", port=5000, debug=True)