百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

【ai】dify+python开发AI八字排盘插件

itomcoil 2025-08-03 05:28 7 浏览

Dify 插件是什么?

你可以将 Dify 插件想象成赋予 AI 应用增强感知和执行能力的模块化组件。它们使得将外部服务、自定义功能以及专用工具以”即插即用”的简洁方式集成到基于 Dify 构建的 AI 应用中成为可能。通过插件,你的 AI 应用可以更好地”看”、“听”、“说”、“画”、“计算”、“推理”,连接外部 API,甚至执行真实世界的操作。

为什么选择开发 Dify 插件?

扩展 AI 能力: 为基于 Dify 的应用赋予专业工具、多模态处理、连接现实世界服务等无限可能。

定制化 Dify 体验: 通过构建专属插件,精准满足特定业务场景或工作流的需求。

重塑智能流程: 利用自定义工具和 Agent 策略,优化 RAG 流程、增强 Agent 推理能力。

实现模块化与解耦: 将功能作为独立的插件进行开发和管理,提高代码的可维护性和灵活性。

享受开发者友好体验: 我们提供强大的 SDK、便捷的远程调试工具和清晰的文档,助你高效开发。

AI 应用

Dify 插件是赋予 AI 应用增强感知和执行能力的模块化组件。可以将外部服务、自定义功能以及专用工具以”即插即用”的简洁方式集成到基于 Dify 构建的 AI 应用中。

dify支持的开发插件类型: 针对每种插件类型,提供专门的开发指南:

模型 (Models: 学习如何将不同的 AI 模型打包、配置并作为插件进行管理。

工具 (Tools): 为 Agent 和工作流构建专业能力,如数据分析、内容处理、自定义集成等。

Agent 策略 (Agent Strategies): 创建自定义的推理策略(如 ReAct, CoT, ToT)来赋能 Dify 中的自主 Agent。

扩展 (Extensions): 通过 HTTP Webhook 实现与外部服务的集成,处理复杂逻辑。

包 (Bundles): 了解如何将多个插件组合打包,以便于分发和部署


Dify 标准结构介绍

your_plugin/
├── _assets/             # 图标和视觉资源
├── provider/            # 提供者定义和验证
│   ├── your_plugin.py   # 凭证验证逻辑
│   └── your_plugin.yaml # 提供者配置
├── tools/               # 工具实现
│   ├── feature_one.py   # 工具功能实现
│   ├── feature_one.yaml # 工具参数和描述
│   ├── feature_two.py   # 另一个工具实现
│   └── feature_two.yaml # 另一个工具配置
├── utils/               # 辅助函数
│   └── helpers.py       # 通用功能逻辑
├── working/             # 进度记录和工作文件
├── .env.example         # 环境变量模板
├── main.py              # 入口文件
├── manifest.yaml        # 插件主配置
├── README.md            # 文档
└── requirements.txt     # 依赖列表
  • main.py 整个项目的入口文件manifest.yaml 整个插件的基础配置文件
    • 插件描述
    • resource所需资源(权限、内存)
    • plugins 指向provider
    • meta 支持的架构、python版本、隐私协议,仓库地址等
  • provider 插件描述
    • your_plugin.py 验证这个插件的依赖、环境、资源等
    • your_plugin.yaml 描述了这个插件是干什么的,有哪些工具,这个是dify查找工具的入口
  • tools 工具的实现目录
    • 一个工具一组py和yaml
    • py为对应的工具的实现,需要符合dify的规范
    • yaml 有几个作用
      1. 识工具的唯一性identity
      2. description描述工具
      3. parameters 工具所需的参数
      4. extra 指定工具的实现python
  • requirements.txt包含所有依赖


  • 实现

    温馨提示:如果大家使用agent开发,比如cursor、codebuddy,可以直接使用官方的提示词。

    dify提供了一个dify-plugin-daemon 工具用于辅助开发,是一个脚手架,可以直接一步步的执行,生成框架。

    # 复制工具YAML文件作为模板
    cp tools/existing_tool.yaml tools/new_feature.yaml
    # 复制工具Python实现
    cp tools/existing_tool.py tools/new_feature.py
    • 更新YAML中的名称、描述和参数
    • 更新Python文件中的类名和实现逻辑
    • 确保每个文件只包含一个Tool子类

    在provider/your_plugin.yaml中添加新工具:

    tools:
      - tools/existing_tool.yaml
      - tools/new_feature.yaml  # 添加新工具

    插件初始化

    1、执行 .\dify-plugin.exe plugin init

    2、填写插件名称、Author、和插件描述

    3、上下键选择插件类型,选中以后回车

    4、上下键选择权限,然后tab切换选中

    5、描述最小版本

    一路按提示操作,最后会生成基础版本的插件。

    调试

    在.env文件中修改REMOTE_INSTALL_URLREMOTE_INSTALL_KEY

    执行python -m main

    安装插件

    dify 的插件,默认是开启签名认证的。有两种方案:

    1、关闭签名验证

    在dify部署的.env中,搜索FORCE_VERIFYING_SIGNATURE,并改为false

    FORCE_VERIFYING_SIGNATURE=false
    //之后
    docker compose down
    docker compose up -d
    • 使用自签名(只能在开源版本中使用,官方是单独的一套)

    执行下面的命令,-f 后面为插件名。

    .\dify-plugin.exe signature generate -f wuyunliuqi

    生成公钥和私钥对

    o wuyunliuqi.private.pem 私钥,用来加签名

    o wuyunliuqi.public.pem 公钥,用来验签名

    # 先打包 会打包出来一个wuyunliuqi.difypkg 文件
    .\dify-plugin.exe plugin package .\wuyunliuqi
    
    # 加签,使用指定的签名对wuyunliuqi.difypkg 进行加签,
    .\dify-plugin.exe signature sign wuyunliuqi.difypkg -p wuyunliuqi.private.pem

    修改docker-compose文件,在plugin_daemon中添加公钥

    plugin_daemon:  
    image:langgenius/dify-plugin-daemon:0.1.2-local
    restart:always
    environment:
        THIRD_PARTY_SIGNATURE_VERIFICATION_ENABLED:true
        THIRD_PARTY_SIGNATURE_VERIFICATION_PUBLIC_KEYS: /app/storage/public_keys/wuyunliuqi_key.public.pem

    这种自签名比较适合,有源码,有多个插件,都可以用这对公私钥进行加签验签。

    插件应用

    1、添加节点的时候,直接选择工具

    2、找到自己开发的插件,然后添加插件进去

    3、设置对应的变量即可


    常见错误排查

    当遇到Multiple subclasses of Tool错误时:

    1. 检查问题文件
    • 寻找形如class AnotherTool(Tool):的额外类定义
    • 确保文件中只有一个继承自Tool的类
    • 例如:如果encrypt.py包含EncryptTool和DecryptTool,保留EncryptTool并将DecryptTool移至decrypt.py
    1. 检查导入错误
    • 确认导入的函数名或类名是否拼写正确
    • 注意下划线、大小写等细节
    • 修正导入语句中的拼写错误## 文件结构与代码组织规范


    当遇到xxx error for ToolProviderConfiguration错误时:

    出现该报错,直接看工具的yaml文件,根据提示,比如下面的报错,缺少identity和extra(这是用大模型生成的时候报的)

    ValueError: Error loading plugin configuration: 3 validation errors for ToolProviderConfiguration
    identity.description - Field required
    identity.icon - Field required  
    extra - Field required
    


    当遇到Failed to parse response from plugin daemon to PluginDaemonBasicResponse [PluginToolProviderEntity]错误时:

    PS:装完插件所有插件都不能用了

    缺少了main.py文件。每个Dify插件都必须有这个入口文件:

    from dify_plugin import Plugin, DifyPluginEnv  
      
    plugin = Plugin(DifyPluginEnv(MAX_REQUEST_TIMEOUT=120))  
      
    if __name__ == '__main__':  
        plugin.run()  


    遇到invalid parameter type 'text-input'错误时:

    大模型在YAML里写的参数类型是text-input,但Dify框架不支持这个类型。

    • type (必填)参数类型,目前支持string、number、boolean、select、secret-input、file、files、model-selector、app-selector 九种类型,分别对应字符串、数字、布尔值、下拉框、加密输入框、文件、文件集、模型选择、应用选择,对于敏感信息,请使用 secret-input 类型。
    • form (必填)表单类型,目前支持llm、form两种类型,建议填写llm不要填写form


    总结

    Dify插件开发整体还算友好,但坑也不少……

    遇到问题时,优先查官方文档和示例代码(示例代码比较老旧),AI只能做参考,避免被带跑偏,走弯路浪费更多时间和精力。

    相关推荐

    python学习教程-第七节内容

    函数(重点)基本概念Python函数的语法是编程中的核心概念之一,它允许你将代码块封装为可重复调用的单元。基本语法定义函数:示例参数类型位置参数(PositionalArguments)按参数定义...

    Python排序90%人只会用sorted()?这7个高阶技巧让你代码效率翻倍

    高效处理数据的关键,往往从掌握排序开始。排序操作在Python编程中的重要性常被低估——直到你面对一个杂乱无章的数据集。作为数据处理的核心操作之一,排序效率直接决定了程序性能和代码可读性。无论你正在清...

    第四章:Python函数

    4.1函数的定义与调用4.1.1理论知识函数是组织好的、可重复使用的代码块,用于执行特定的任务。它可以提高代码的复用性和可维护性。在Python中,定义函数使用def关键字,其基本语法如下:def...

    ArcGIS 一个独立运行的Python程序编写和打包

    写代码#coding=utf8#-*-coding:UTF-8-*-importarcpyfromarcpyimportenvimportosimportsys##########...

    python入门到脱坑经典案例—计算三角形的面积

    下面为大家详细讲解如何用Python计算三角形面积。我们会从最基础的数学公式开始,逐步深入编程实现,并涵盖多个实用版本。以下是完整的教学指南:1.数学原理回顾三角形面积公式:面积=(底边长度...

    Python运算技巧:10种计算列表平方的高效方法

    1.使用for循环此方法遍历列表中的每个数字,使用**运算符计算其平方,然后将结果添加到新的列表中。2.使用列表推导式此方法使用列表推导式,这是一种更简洁的方式,可以在现有列表的每个项目上执行操作...

    墙裂推荐,5个学习Python编程最佳的开源库

    学习Python少不了的就是项目,我在GitHUB上找了几个比较好的开源库,大家可以跟着去学习。1、learn-python3这个存储库一共有19本Jupyter笔记本。它涵盖了字符串和条件之类的基础...

    使用Python玩转ftplib库:实现ftp文件传输自动化全攻略

    大家好!在日常工作中都会使用到ftp功能,用于上传和下载文件等,本章主要介绍Python的标准库ftplib来实现FTP文件传输,帮助我们实现ftp自动化。一、ftplib库核心函数速查表1连接与登...

    Python零基础入门学习23:常用第三方库之图像处理库Pillow

    注:本文所有代码均经过Python3.7实际运行检验,保证其严谨性。本文约2000字,阅读时间约为4分钟。Pillow库的概述Pillow库是Python最好的图像处理库,可能是使用频率最高的图像处...

    Python编程之BeautifulSoup库

    #头条创作挑战赛#BeautifulSoup是一个可以从HTML或XML文件中快速提取数据的Python库。它能够通过转从入门到精通Python网络爬虫框架Scrapy38换器实...

    Python3 新一代Http请求库Httpx使用(详情版)

    我们经常使用Python语言的朋友们都清楚,requests是使用率非常高的HTTP库,甚至更早Python2中使用的是urllib、urllib2,也给我们提供了许多方便的功能。但是自从...

    小白也可以玩的Python爬虫库,收藏一下

    最近,微软开源了一个项目叫「playwright-python」,作为一个兴起项目,出现后受到了大家热烈的欢迎,那它到底是什么样的存在呢?今天为你介绍一下这个传说中的小白神器。Playwright是...

    apscheduler,一个超厉害的 Python 库!

    大家好,今天为大家分享一个超厉害的Python库-apscheduler。Github地址:https://github.com/agronholm/apschedulerAPSchedule...

    给3D Slicer添加Python第三方插件库

    对临床医生或医学影像算法研究人员来说,3DSlicer是不错的临床实践或科研工具。随着人工智能和深度学习技术的普及,python已经作为原型开发和验证的计算机编程语言。3DSlicer自带pyt...

    Paramiko:一个非常实用的Python库

    前言Python的Paramiko库,它是一个用于实现SSHv2协议的客户端和服务器的库。通过使用Paramiko,我们可以在Python程序中轻松地实现远程服务器的管理、文件传输等功能。特别做智能硬...