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
  • 无命名冲突
  • 可直接运行
相关推荐
石工记7 小时前
CTO如何落地AI?从0到1的实战路径
人工智能·python·django·flask·numpy·pandas·pyqt
Shan120510 小时前
浅谈:无服务器WebSocket解决方案
云原生·flask·serverless
知识分享小能手1 天前
Flask入门学习教程,从入门到精通,Flask智能租房——用户中心知识点详解(9)
python·学习·flask
輕華1 天前
Flask_GET请求与JSON响应实战详解
python·flask·json
TE-茶叶蛋2 天前
Graph RAG Agent 系统深度分析
后端·python·flask
知识分享小能手2 天前
Flask入门学习教程,从入门到精通,Flask智能租房——详情页完整知识点详解(8)
python·学习·flask
24kmaigc3 天前
NewStarCTF2025-ssti在哪里?-ssrf与ssti注入
python·网络安全·flask·web
知识分享小能手3 天前
Flask入门学习教程,从入门到精通,Flask智能租房——列表页 知识点详解(7)
python·学习·flask
布吉岛的石头3 天前
Java 程序员第 34 阶段大模型权限与安全设计:接口鉴权与访问控制落地
java·安全·flask
码界筑梦坊3 天前
153-基于FLask的英国希思罗机场天气数据可视化分析系统
python·信息可视化·数据分析·flask