Python Flask 开发 - Flask 快速上手(Flask 最简单的案例、Flask 处理跨域、Flask 基础接口)

一、Flask 最简单的案例

  1. 安装 flask 模块
shell 复制代码
pip install flask
  1. 导入 flask 模块,实现最简单的案例
python 复制代码
from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello():
    return 'Hello World'


if __name__ == '__main__':
    app.run()

二、Flask 处理跨域

  1. 安装 flask-cors 模块
shell 复制代码
pip install flask-cors
  1. 导入 flask-cors 模块,处理跨域
python 复制代码
from flask_cors import CORS

...

CORS(app)

三、Flask 基础接口

1、不带参数的 GET 请求
python 复制代码
@app.route('/test')
def test():
    return 'Test Page'
js 复制代码
// Promise 风格

fetch("http://127.0.0.1:5000/test", {
    method: "GET",
})
    .then((response) => response.text()) // 解析数据
    .then((data) => console.log(data)) // 处理数据
    .catch((error) => console.error("Error:", error)); // 处理错误
js 复制代码
// async await 风格

try {
    const response = await fetch("http://127.0.0.1:5000/test", {
        method: "GET",
    });

    const data = await response.text();

    console.log(data);
} catch (error) {
    console.error("Error:", error);
}
2、带参数的 GET 请求
  1. 路径参数
python 复制代码
@app.route('/showUsername/<username>')
def show_username(username):
    print(f'username type: {type(username)}')
    return f'username: {username}'
js 复制代码
try {
    const response = await fetch("http://127.0.0.1:5000/showUsername/test123", {
        method: "GET",
    });

    const data = await response.text();

    console.log(data);
} catch (error) {
    console.error("Error:", error);
}
  1. 查询参数
python 复制代码
@app.route('/showUserId')
def show_userId():
    userId = request.args.get('userId')
    print(f'userId type: {type(userId)}')
    return f'userId: {userId}'
js 复制代码
try {
    const response = await fetch("http://127.0.0.1:5000/showUserId?userId=test123", {
        method: "GET",
    });

    const data = await response.text();

    console.log(data);
} catch (error) {
    console.error("Error:", error);
}
3、POST 请求
  1. 表单数据
python 复制代码
@app.route('/login', methods=['POST'])
def login():
    username = request.form['username']
    password = request.form['password']
    print(f'username type: {type(username)}')
    print(f'password type: {type(password)}')
    print(f'username: {username}, password: {password}')

    return 'Login Page'
js 复制代码
const formData = new FormData();
formData.append("username", "admin");
formData.append("password", "123456");

try {
    const response = await fetch("http://127.0.0.1:5000/login", {
        method: "POST",
        body: formData,
    });

    const data = await response.text();

    console.log(data);
} catch (error) {
    console.error("Error:", error);
}
  1. JSON 数据
python 复制代码
@app.route('/login', methods=['POST'])
def login():
    data = request.get_json()
    username = data['username']
    password = data['password']
    print(f'username type: {type(username)}')
    print(f'password type: {type(password)}')
    print(f'username: {username}, password: {password}')

    return 'Login Page'
js 复制代码
try {
    const response = await fetch("http://127.0.0.1:5000/login", {
        method: "POST",
        headers: {
            "Content-Type": "application/json",
        },
        body: JSON.stringify({
            username: "admin",
            password: "123456",
        }),
    });

    const data = await response.text();

    console.log(data);
} catch (error) {
    console.error("Error:", error);
}
相关推荐
leobertlan3 小时前
2025年终总结
前端·后端·程序员
面向Google编程3 小时前
从零学习Kafka:数据存储
后端·kafka
invicinble3 小时前
对linux形成认识
linux·运维·服务器
冷雨夜中漫步4 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
技术路上的探险家4 小时前
8 卡 V100 服务器:基于 vLLM 的 Qwen 大模型高效部署实战
运维·服务器·语言模型
郝学胜-神的一滴4 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再4 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
半桔4 小时前
【IO多路转接】高并发服务器实战:Reactor 框架与 Epoll 机制的封装与设计逻辑
linux·运维·服务器·c++·io
绵绵细雨中的乡音4 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
易安说AI4 小时前
Claude Opus 4.6 凌晨发布,我体验了一整晚,说说真实感受。
后端