Flask Blueprint:URL ID 传递问题及解决方案

碧海醫心
发布: 2025-11-16 11:25:22
原创
294人浏览过

flask blueprint:url id 传递问题及解决方案

本文针对 Flask Blueprint 中使用 POST 请求传递 URL ID 时遇到的 404 错误,提供了一种解决方案。通过分析问题原因,阐述了在 JavaScript 中构建请求 URL 的正确方法,避免了 Blueprint 路由匹配失败的问题,确保请求能够正确地路由到 Blueprint 中的端点。

在使用 Flask Blueprint 构建 Web 应用时,经常需要在 URL 中传递 ID 作为参数。如果在前端使用 JavaScript 发起 POST 请求时,URL 构建不正确,可能会导致 404 错误。下面将详细介绍这个问题的原因以及解决方案。

问题分析

当我们在页面 localhost/2/updatestrat 上,尝试通过 JavaScript 发起 POST 请求到 /add_indicator 时,期望 Flask Blueprint 能够正确地将 URL 中的 ID (例如:2) 传递到 add_indicator 函数。然而,如果直接使用 /add_indicator 作为 endpoint,请求实际上会发送到 http://127.0.0.1:5000/add_indicator,而不是 http://127.0.0.1:5000/2/add_indicator。这导致 Flask 无法找到匹配的路由,从而返回 404 错误。

getJson 函数之所以能够正常工作,是因为它在没有明确指定根路径的情况下,浏览器会自动将当前页面的路径作为基础路径,从而正确地发送到 /2/load_conditions。

解决方案

解决方案在于,在 JavaScript 中构建请求 URL 时,要确保 URL 与 Blueprint 中定义的路由相匹配。

错误示例:

AI建筑知识问答
AI建筑知识问答

用人工智能ChatGPT帮你解答所有建筑问题

AI建筑知识问答 22
查看详情 AI建筑知识问答
let indi_data = await postJsonGetData(data, "/add_indicator"); // 错误:缺少 ID
登录后复制

正确示例:

let indi_data = await postJsonGetData(data, "add_indicator"); // 正确:相对路径,自动包含 ID
登录后复制

或者,更明确的方式:

let strategyId = 2; // 或者从页面元素中获取
let indi_data = await postJsonGetData(data, `${strategyId}/add_indicator`); // 明确构建 URL
登录后复制

在 Flask Blueprint 中,路由定义如下:

from flask import Blueprint, request, jsonify
from flask_login import login_required

bp = Blueprint('my_blueprint', __name__)

@bp.route('/<int:strategy_id>/add_indicator', methods=['POST'])
@login_required
def add_indicator(strategy_id):
    if request.method == 'POST':
        data = request.get_json() # 获取 POST 请求中的 JSON 数据
        print(f"Strategy ID: {strategy_id}")
        print(f"Received data: {data}")
        return jsonify({"message": "Indicator added successfully"}) # 返回 JSON 响应
登录后复制

代码解释

  1. Blueprint 定义: 使用 Blueprint 类创建一个 Blueprint 实例,命名为 my_blueprint。
  2. 路由定义: @bp.route('/<int:strategy_id>/add_indicator', methods=['POST']) 定义了一个路由,该路由接受一个整数类型的 strategy_id 作为 URL 参数,并且只响应 POST 请求。
  3. add_indicator 函数: 这个函数处理 POST 请求。它接收 strategy_id 作为参数,并从 request 对象中获取 JSON 数据。 request.get_json() 用于解析请求体中的 JSON 数据。
  4. JSON 响应: jsonify({"message": "Indicator added successfully"}) 创建一个 JSON 响应,包含一个 message 键,值为 "Indicator added successfully"。

注意事项

  • 确保 Blueprint 已经正确注册到 Flask 应用中。
  • 在 JavaScript 中,如果使用绝对路径 /add_indicator,则 Flask 会认为该路由在根目录下,而不是在 Blueprint 中。
  • 在 Flask 中,使用 request.get_json() 可以方便地获取 POST 请求中的 JSON 数据。

总结

在使用 Flask Blueprint 时,正确构建 URL 至关重要。通过使用相对路径或者明确地构建包含 ID 的 URL,可以避免 404 错误,确保 POST 请求能够正确地路由到 Blueprint 中的端点。同时,合理使用 Flask 提供的工具函数,如 request.get_json() 和 jsonify(),可以简化请求处理和响应构建。

以上就是Flask Blueprint:URL ID 传递问题及解决方案的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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