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)

运行截图如下:

相关推荐
qeen879 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
m0_736034859 小时前
存储基础和虚拟化
笔记
AOwhisky11 小时前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算
华山沦贱12 小时前
open62541 V1.5.4版对C++ Builder支持的bug
笔记
稷下元歌12 小时前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
逸模12 小时前
AI+BIM 重构连锁公装新范式 逸模打造数字化营建核心底座
大数据·人工智能·笔记·其他·信息可视化·重构
xqqxqxxq13 小时前
树结构技术学习笔记
数据结构·笔记·学习
十月的皮皮14 小时前
C语言学习笔记202606008- 三角形判断(3种方法)
c语言·笔记·学习
XGeFei14 小时前
【Fastapi学习笔记(6)】—— Fastapi文件上传、请求头自动转换
笔记·学习·fastapi
嘶哈哈哈14 小时前
嘉立创 EDA 入门实操笔记:从原理图到 PCB 布线、差分对、覆铜与 DRC 检查
开发语言·笔记·php