0

0

Flask 400 错误排查:正确使用 FormData 发送 POST 请求

心靈之曲

心靈之曲

发布时间:2025-12-29 23:04:02

|

633人浏览过

|

来源于php中文网

原创

Flask 400 错误排查:正确使用 FormData 发送 POST 请求

flask 接收 xmlhttprequest 的 post 数据时返回 400 错误,通常是因为前端未按 `application/x-www-form-urlencoded` 格式提交数据,而 flask 的 `request.form` 仅解析该格式;解决方案是改用 `formdata` 对象封装数据并发送。

在 Flask 中,request.form 是一个类字典对象,专门用于解析标准表单编码(即 Content-Type: application/x-www-form-urlencoded)的请求体。当你直接调用 xmlhttp.send("json=" + encodeURI(...)) 时,虽然字符串结构看似符合表单格式,但 默认情况下 XMLHttpRequest 并未设置正确的 Content-Type 头,导致 Flask 无法识别并解析请求体,进而抛出 400 Bad Request 错误(常见于访问 request.form["json"] 时触发 BadRequestKeyError 或空值校验失败)。

✅ 正确做法是使用 FormData 对象 —— 它会自动设置 Content-Type: multipart/form-data(或在无文件时退化为 application/x-www-form-urlencoded),并确保键值对被 Flask 正确捕获:

function del(e) {
    const getXmlhttp = new XMLHttpRequest();
    getXmlhttp.onload = function () {
        try {
            const json = JSON.parse(this.responseText);
            const newJson = json.filter(item => item.name !== e.parentElement.childNodes[2].textContent);

            const postXmlhttp = new XMLHttpRequest();
            postXmlhttp.open("POST", "/orders");
            postXmlhttp.onreadystatechange = function () {
                if (postXmlhttp.readyState === 4 && postXmlhttp.status === 200) {
                    // 可选:刷新页面或更新 UI
                    location.reload();
                }
            };

            const formData = new FormData(); // ✅ 创建 FormData 实例
            formData.append("json", JSON.stringify(newJson)); // ✅ 自动编码,无需手动 encodeURI

            postXmlhttp.send(formData); // ✅ 自动设置合适 Content-Type
        } catch (err) {
            console.error("JSON 解析或请求处理失败:", err);
        }
    };
    getXmlhttp.open("GET", "/json");
    getXmlhttp.send();
}

⚠️ 同时,后端 Flask 路由也需增强健壮性,避免因缺失字段或空值引发异常:

寻鲸AI
寻鲸AI

寻鲸AI是一款功能强大的人工智能写作工具,支持对话提问、内置多场景写作模板如写作辅助类、营销推广类等,更能一键写作各类策划方案。

下载
@app.route("/orders", methods=["POST", "GET"])
def order():
    global orders
    if request.method == "GET":
        return render_template("orders.html", orders=orders)

    # 安全地获取 form 数据
    json_str = request.form.get("json")
    if not json_str:
        return "Missing 'json' field", 400

    try:
        orders = json.loads(unquote(json_str))
        newOrder(orders)  # 假设 newOrder 接收解析后的列表
        return "", 204  # No Content 表示成功处理
    except json.JSONDecodeError:
        return "Invalid JSON in 'json' field", 400
    except Exception as e:
        return f"Server error: {str(e)}", 500

? 关键要点总结:

  • ❌ 不要手动拼接查询字符串(如 "json=" + ...)并用 send() 发送纯文本;
  • ✅ 必须使用 FormData 封装键值对,让浏览器自动处理编码与头部设置;
  • ✅ 后端务必使用 request.form.get(key) 替代 request.form[key],防止 KeyError;
  • ✅ 始终校验输入、捕获 JSON 解析异常,并返回明确的 HTTP 状态码便于前端调试。

遵循以上规范,即可彻底解决 Flask + XMLHttpRequest 场景下的 400 错误问题。

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

82

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

64

2025.12.15

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

401

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

204

2023.09.04

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.1万人学习

CSS教程
CSS教程

共754课时 | 17万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号