Java集成Dify AI服务的客户端工具包

项目源码

Dify Java SDK是为Java开发者设计的开源工具包,专门用于与Dify AI平台的无缝对接。该工具包全面覆盖了Dify平台的各项API功能,使开发者能够便捷地在Java应用中调用AI服务。

核心功能

本工具包具备以下主要特性:

1. 多场景应用支持

  • 智能对话系统:通过专用接口实现多轮对话管理
  • 文本自动生成:支持各类文本内容的智能创作
  • 流程化对话:适用于复杂业务流程的对话管理
  • 自动化流程:实现多步骤任务的智能编排
  • 知识图谱:提供知识库的创建与检索功能

2. 多样化交互方式

  • 同步请求:即时获取完整响应内容
  • 实时流传输:支持内容的分段接收
  • 多媒体处理:包含语音文字互转等功能

3. 对话系统管理

  • 会话的创建与维护
  • 历史记录查询
  • 会话信息修改
  • 反馈信息提交
  • 智能问题推荐

4. 知识库全周期管理

  • 知识库的建立与维护
  • 文档的上传与管理
  • 内容分块处理
  • 语义化搜索

5. 可定制化配置

  • 连接时长设置
  • 读写超时调整
  • 自定义HTTP客户端

环境配置

运行要求

  • JDK 1.8及以上版本
  • Maven 3.x或Gradle 4.x以上

Maven引入

<dependency>
<groupId>io.github.imfangs</groupId>
<artifactId>dify-java-client</artifactId>
<version>1.0.4</version>
</dependency>

Gradle引入

implementation 'io.github.imfangs:dify-java-client:1.0.4'

初始化指南

客户端创建

// 创建通用客户端
DifyClient client = DifyClientFactory.createClient("https://api.dify.ai/v1", "your-api-key");
// 创建专用客户端
DifyChatClient chatClient = DifyClientFactory.createChatClient("https://api.dify.ai/v1", "your-api-key");
// 自定义配置创建
DifyConfig config = DifyConfig.builder()
.baseUrl("https://api.dify.ai/v1")
.apiKey("your-api-key")
.connectTimeout(5000)
.readTimeout(60000)
.writeTimeout(30000)
.build();
DifyClient customClient = DifyClientFactory.createClient(config);

应用示例

1. 智能对话系统

同步模式
DifyChatClient chatClient = DifyClientFactory.createChatClient("https://api.dify.ai/v1", "your-api-key");
ChatMessage message = ChatMessage.builder()
.query("请做自我介绍")
.user("user-123")
.responseMode(ResponseMode.BLOCKING)
.build();
ChatMessageResponse response = chatClient.sendChatMessage(message);
System.out.println("响应内容: " + response.getAnswer());
实时模式
chatClient.sendChatMessageStream(message, new ChatStreamCallback() {
@Override
public void onMessage(MessageEvent event) {
System.out.println("实时内容: " + event.getAnswer());
}
@Override
public void onMessageEnd(MessageEndEvent event) {
System.out.println("消息ID: " + event.getMessageId());
}
});

2. 文本生成服务

同步请求
DifyCompletionClient completionClient = DifyClientFactory.createCompletionClient("https://api.dify.ai/v1", "your-api-key");
Map<String, Object> inputs = new HashMap<>();
inputs.put("content", "科技");
CompletionRequest request = CompletionRequest.builder()
.inputs(inputs)
.responseMode(ResponseMode.BLOCKING)
.user("user-123")
.build();
CompletionResponse response = completionClient.sendCompletionMessage(request);
System.out.println("生成内容: " + response.getAnswer());

3. 知识库管理

文档操作
DifyDatasetsClient datasetsClient = DifyClientFactory.createDatasetsClient("https://api.dify.ai/v1", "your-api-key");
CreateDocumentByTextRequest docRequest = CreateDocumentByTextRequest.builder()
.name("示例文档")
.text("文档示例内容")
.indexingTechnique("high_quality")
.build();
DocumentResponse docResponse = datasetsClient.createDocumentByText(datasetId, docRequest);
System.out.println("文档ID: " + docResponse.getDocument().getId());

接口说明

客户端分类

类型 说明 功能
通用客户端 全功能支持 所有API调用
对话客户端 专注对话场景 对话管理与反馈
文本客户端 文本生成专用 内容创作控制
知识库客户端 知识管理专用 文档与检索管理
#### 响应类型
模式 枚举值 说明
---- -------- -----
同步 BLOCKING 即时完整响应
实时 STREAMING 分段内容接收
### 高级设置
#### 自定义HTTP配置
DifyConfig config = DifyConfig.builder()
.baseUrl("https://api.dify.ai/v1")
.apiKey("your-api-key")
.connectTimeout(5000)
.readTimeout(60000)
.writeTimeout(30000)
.build();
DifyClient client = DifyClientFactory.createClient(config);

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/9336.html

(0)
LomuLomu
上一篇 2025 年 5 月 13 日 上午1:57
下一篇 2025 年 5 月 13 日 上午2:58

相关推荐

  • manim边学边做–移动动画

    在Manim动画库中,实现直线移动动画是一项基础而直接的任务,每个Mobject对象都配备了animate属性,使得通过obj.animate.shift()或obj.animate.move_to()将对象从一个位置移动到另一个位置变得轻而易举。 然而,对于需要遵循复杂路径的移动动画,标准的animate方法就显得力不从心了。本文将深入探讨Manim中两个…

    未分类 2024 年 12 月 26 日
    35800
  • manim边做边学–动画更新

    今天介绍Manim中用于动画更新的3个类 ,分别是: UpdateFromFunc:根据自定义的函数来动态更新 Mobject 的属性 UpdateFromAlphaFunc:根据动画的进度来平滑地改变 Mobject 的属性 MaintainPositionRelativeTo:保持多个 Mobject 之间的相对位置关系 这3个类 分别从自定义更新、基于…

    2025 年 1 月 12 日
    38000
  • 高性能MySQL(第4版)PDF、EPUB免费下载

    适读人群 :不但适合数据库管理员(DBA)阅读,也适合开发人员参考学习。不管是数据库新手还是专家,相信都能从本书有所收获 领域经典十年后全版更新||全面拥抱8.0||重磅剖析现代云数据库与大规模运维实践||中国首批DBA精琢翻译5大头部国产数据库创始人联合力荐 电子版仅供预览,下载后24小时内务必删除,支持正版,喜欢的请购买正版书籍 点击原文去下载 书籍信息…

    2025 年 1 月 6 日
    32400
  • JAVA 图形界面编程 AWT篇(1)

    前言 为了完成JAVA课程设计,我踏上了Java图形界面编程的学习之旅,通过撰写博客记录我的学习过程和心得。 AWT(Abstract Window Toolkit)概览 AWT(抽象窗口工具包)是Java早期的图形用户界面(GUI)框架之一,主要被用于构建桌面应用程序的图形界面。它最初在JDK 1.0版本中作为Java GUI的核心库引入,目的是提供一个能…

    未分类 2024 年 12 月 28 日
    34800
  • 数据结构(Java版)第六期:LinkedList与链表(一)

    目录 一、链表 1.1. 链表的概念及结构 1.2. 链表的实现 专栏:数据结构(Java版) 个人主页:手握风云 一、链表 1.1. 链表的概念及结构 链表是⼀种物理存储结构上⾮连续存储结构,数据元素的逻辑顺序是通过链表中的引⽤链接次序实现的。与火车类似,火车头、车厢与每一届车厢之间由火车链连接起来。在物理上,链表是不一定连续的,但在逻辑上一定是连续的。 …

    2025 年 1 月 16 日
    24200

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信