Dify笔记-创建自定义工具连接到自建的OpenAPI Schema服务

背景

使用Python的Flask包创建OpenAPI Schema服务,提供给Dify创建自定义工具使用。

使用Flask的原因是,国产系统,内网系统,共用系统。安装OpenSSL开发环境不方便,特别是内网和共用系统,有很大风险。

甚至弄坏其他项目。所以采用Flask。不依赖OpenSSL。

操作

dify成功配置如下:

代码如下:

python 复制代码
from flask import Flask, jsonify, request

app = Flask(__name__)

# ------------------------------
# 1. OpenAPI 规范定义(给导入工具用的)
# ------------------------------
OPENAPI_SCHEMA = {
    "openapi": "3.0.0",
    "info": {
        "title": "FLASK_TEST API",
        "version": "1.0.0"
    },
    "servers": [
        {"url": "http://192.168.240.1:9123"}  # 这里改成实际IP
    ],
    "paths": {
        "/add": {
            "post": {
                "summary": "两数相加",
                "requestBody": {
                    "required": True,
                    "content": {
                        "application/json": {
                            "schema": {
                                "type": "object",
                                "properties": {
                                    "a": {"type": "number"},
                                    "b": {"type": "number"}
                                },
                                "required": ["a", "b"]
                            }
                        }
                    }
                },
                "responses": {
                    "200": {
                        "description": "成功返回和",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "type": "object",
                                    "properties": {
                                        "result": {"type": "number"}
                                    }
                                }
                            }
                        }
                    }
                }
            }
        },
        "/echo": {
            "post": {
                "summary": "返回输入的消息",
                "requestBody": {
                    "required": True,
                    "content": {
                        "application/json": {
                            "schema": {
                                "type": "object",
                                "properties": {
                                    "message": {"type": "string"}
                                },
                                "required": ["message"]
                            }
                        }
                    }
                },
                "responses": {
                    "200": {
                        "description": "成功返回消息",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "type": "object",
                                    "properties": {
                                        "result": {"type": "string"}
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}

# ------------------------------
# 2. 提供 OpenAPI Schema 接口(关键!给导入用)
# ------------------------------
@app.route('/openapi.json', methods=['GET'])
def openapi_schema():
    return jsonify(OPENAPI_SCHEMA)

# ------------------------------
# 3. 实际业务接口
# ------------------------------
@app.route('/add', methods=['POST'])
def add():
    data = request.get_json()
    a = data['a']
    b = data['b']
    return jsonify({"result": a + b})

@app.route('/echo', methods=['POST'])
def echo():
    data = request.get_json()
    message = data['message']
    return jsonify({"result": message})

# ------------------------------
# 启动服务
# ------------------------------
if __name__ == '__main__':
    app.run(host="0.0.0.0", port=9123, debug=False, use_reloader=False)

运行截图如下:

相关推荐
RainCity1 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
LinXunFeng8 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星13 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq13 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波13 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.13 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余13 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.13 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央13 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器13 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记