Flask + MySQL 极简 Web 项目搭建

Flask + MySQL 极简 Web 项目搭建

一、项目结构(超干净)

|------------------------------------------------------------------------------------|
| Plain Text flask_demo/ ├── app.py # 主程序 ├── requirements.txt # 依赖 └── .env # 数据库配置 |

二、requirements.txt(直接复制)

|---------------------------------------------------------------|
| txt flask flask-sqlalchemy pymysql python-dotenv cryptography |

三、.env 数据库配置

|-------------------------------------------------------------------------------------|
| env DB_HOST=localhost DB_USER=root DB_PASSWORD=你的密码 DB_NAME=flask_demo DB_PORT=3306 |

四、app.py(app.py)(完整可运行代码)

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| python from flask import Flask, request, jsonify from flask_sqlalchemy import SQLAlchemy from dotenv import load_dotenv import os # 加载环境变量 load_dotenv() # 初始化 Flask app = Flask(name) # 连接 MySQL app.config'SQLALCHEMY_DATABASE_URI' = f"mysql+pymysql://{os.getenv('DB_USER')}:{os.getenv('DB_PASSWORD')}@{os.getenv('DB_HOST')}:{os.getenv('DB_PORT')}/{os.getenv('DB_NAME')}" app.config'SQLALCHEMY_TRACK_MODIFICATIONS' = False # 初始化数据库 db = SQLAlchemy(app) # ==================== 数据库模型 ==================== class User(db.Model): tablename = "users" id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50)) email = db.Column(db.String(100), unique=True) age = db.Column(db.Integer) # ==================== 接口(CRUD) ==================== # 1. 创建用户 @app.route('/user', methods='POST') def create_user(): data = request.json user = User(name=data'name', email=data'email', age=data.get('age')) db.session.add(user) db.session.commit() return jsonify({"msg": "创建成功", "id": user.id}) # 2. 查询所有用户 @app.route('/users', methods='GET') def get_users(): users = User.query.all() res = {"id": u.id, "name": u.name, "email": u.email, "age": u.age} for u in users return jsonify(res) # 3. 查询单个用户 @app.route('/user/<int:id>', methods='GET') def get_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 return jsonify({"id": user.id, "name": user.name, "email": user.email, "age": user.age}) # 4. 更新用户 @app.route('/user/<int:id>', methods='PUT') def update_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 data = request.json user.name = data.get('name', user.name) user.email = data.get('email', user.email) user.age = data.get('age', user.age) db.session.commit() return jsonify({"msg": "更新成功"}) # 5. 删除用户 @app.route('/user/<int:id>', methods='DELETE') def delete_user(id): user = User.query.get(id) if not user: return jsonify({"msg": "用户不存在"}), 404 db.session.delete(user) db.session.commit() return jsonify({"msg": "删除成功"}) # 启动时创建表 with app.app_context(): db.create_all() # 启动 if name == 'main': app.run(debug=True) |

五、运行步骤(超级简单)

1. 安装依赖

|--------------------------------------|
| bash pip install -r requirements.txt |

2. 启动项目

|--------------------|
| bash python app.py |

3. 访问地址

|----------------------------------|
| Plain Text http://127.0.0.1:5000 |

4. 接口列表

  • POST /user → 创建用户
  • GET /users → 获取所有用户
  • GET /user/1 → 获取单个用户
  • PUT /user/1 → 更新用户
  • DELETE /user/1 → 删除用户

✅ 这个 Flask 项目特点

  • 代码最少
  • 结构最简单
  • 直接连接 MySQL
  • 完整 CRUD
  • 无命名冲突
  • 可直接运行
相关推荐
TechWayfarer4 天前
苏超赛事网站安全防护:WAF、DDoS与仿冒页面如何联动治理
网络·python·安全·flask·ddos
vortex54 天前
新手前后端开发学习指南:从Flask框架到全栈实践
后端·python·flask
叫我:松哥4 天前
基于Python flask的中学可控智能命题系统设计与实现,整合遗传算法、DeepSeek 大模型及数据库技术构建一体化应用
数据库·人工智能·python·算法·机器学习·flask·遗传算法
chushiyunen4 天前
langchain4j笔记、tools
笔记·python·flask
叫我:松哥5 天前
基于机器学习的中文文本抑郁症风险检测系统,包括NLP与传统机器学习的抑郁症识别,准确率92%
人工智能·深度学习·机器学习·自然语言处理·flask·nlp·bootstrap
TechWayfarer5 天前
查IP归属地接入实战:保险理赔如何做动态风险监控与预警
网络·python·tcp/ip·安全·flask
2601_961875245 天前
花生十三资源盘|电子版|全科
python·django·flask·virtualenv·scikit-learn·pygame·tornado
叫我:松哥5 天前
基于Flask的在线考试刷题系统设计与实现,集智能练习、过程追踪、深度分析与个性化引导
数据库·人工智能·后端·python·flask·boostrap
abcy0712137 天前
flask hdfs 异步上传图文教程csdn
python·flask
abcy0712137 天前
flask celery hdfs 异步上传
python·hdfs·flask