🔥 Java 的 LLM 框架,Agents-Flex v1.3.5 发布
Agents-Flex: 一个基于 Java 的 LLM 应用开发及编排框架。
经过近 1 年的开发和迭代,Agents-Flex 发布了 30+ 个版本,终于迎来了 v1.0.0 正式版本。
与此同时,基于 Agents-flex 开发的对标 Dify Coze 等产品的 AIFlowy 也正式对外开源,开源地址: https://gitee.com/aiflowy/aiflowy
Agents-Flex 的基本能力
- LLM 的访问能力
- Prompt、Prompt Template 定义加载的能力
- Function Calling 定义、调用和执行等能力
- 记忆的能力(Memory)
- Embedding
- Vector Store
- 文档处理
- 加载器(Loader)
- Http
- FileSystem
- 分割器(Splitter)
- 解析器(Parser)
- PoiParser
- PdfBoxParser
- 加载器(Loader)
- Chain 执行链
- SequentialChain 顺序执行链
- ParallelChain 并发(并行)执行链
- LoopChain 循环执行连
- ChainNode
简单对话
使用 OpenAi 大语言模型:
@Test
public void testChat() {
OpenAiLlmConfig config = new OpenAiLlmConfig();
config.setApiKey("sk-rts5NF6n*******");
Llm llm = new OpenAiLlm(config);
String response = llm.chat("请问你叫什么名字");
System.out.println(response);
}
使用 “通义千问” 大语言模型:
@Test
public void testChat() {
QwenLlmConfig config = new QwenLlmConfig();
config.setApiKey("sk-28a6be3236****");
config.setModel("qwen-turbo");
Llm llm = new QwenLlm(config);
String response = llm.chat("请问你叫什么名字");
System.out.println(response);
}
使用 “讯飞星火” 大语言模型:
@Test
public void testChat() {
SparkLlmConfig config = new SparkLlmConfig();
config.setAppId("****");
config.setApiKey("****");
config.setApiSecret("****");
Llm llm = new SparkLlm(config);
String response = llm.chat("请问你叫什么名字");
System.out.println(response);
}
历史对话示例
public static void main(String[] args) {
SparkLlmConfig config = new SparkLlmConfig();
config.setAppId("****");
config.setApiKey("****");
config.setApiSecret("****");
Llm llm = new SparkLlm(config);
HistoriesPrompt prompt = new HistoriesPrompt();
System.out.println("您想问什么?");
Scanner scanner = new Scanner(System.in);
String userInput = scanner.nextLine();
while (userInput != null) {
prompt.addMessage(new HumanMessage(userInput));
llm.chatStream(prompt, (context, response) -> {
System.out.println(">>>> " + response.getMessage().getContent());
});
userInput = scanner.nextLine();
}
}
Function Calling
- 第一步:通过注解定义本地方法
public class WeatherUtil {
@FunctionDef(name = "get_the_weather_info", description = "get the weather info")
public static String getWeatherInfo(
@FunctionParam(name = "city", description = "the city name") String name
) {
//在这里,我们应该通过第三方接口调用 api 信息
return name + "的天气是阴转多云。 ";
}
}
- 第二步:通过 Prompt、Functions 传入给大模型,然后得到结果
public static void main(String[] args) {
OpenAiLlmConfig config = new OpenAiLlmConfig();
config.setApiKey("sk-rts5NF6n*******");
OpenAiLlm llm = new OpenAiLlm(config);
FunctionPrompt prompt = new FunctionPrompt("今天北京的天气怎么样", WeatherUtil.class);
FunctionResultResponse response = llm.chat(prompt);
Object result = response.getFunctionResult();
System.out.println(result);
//"北京的天气是阴转多云。 "
}
Agents-Flex v1.2.8~1.3.5 更新记录:
- 新增: 新增 ChainNodeValidator 用于给 Node 自定义其验证器
- 新增: 新增 ChainNode.validate 方法,用于校验其数据是否完善
- 新增: 工作流执行新增节点算力消耗的定义
- 新增:Parameter 新增 formPlaceholder 属性
- 新增: getParameterValues 通过 LinkedHashMap 返回属性,支持参数顺序
- 新增:ChatOptions 新增 extra 配置,用于自定义大模型的参数内容
- 新增: ReActAgent 添加 ChatOptions 的设置能力
- 新增: ConfirmParameter 添加更多的配置参数支持
- 新增:代码执行节点添加 “_context” 对象
- 新增:新增 Chain.toJSON() 和 Chain.fromJSON() 方法
- 新增:新增 ConfirmNode 用于支持用户手动确认的场景
- 新增: Chain 新增 getNodeExecuteResult 方法
- 新增:新增 Audio 多模态的支持
- 新增:新增 ReActMessageBuilder,允许用户构建自定义的消息
- 优化:feat: 修改 TextAndImageMessage 和 TextAndAudioMessage 为 HumanImageMessage 和 HumanAudioMessage
- 优化:优化重构 EdgeCondition 和 NodeCondition 方法
- 优化:优化 Chain.getParameterValues 方法
- 优化:移动 Chain 监听器的相关类到 listener 包里去
- 优化: 优化 getParameterValues 的错误信息
- 优化: 移除 chain 非必要的 error 日志
- 优化: 优化 Chain.getParameterValues
- 优化:优化合并 ConfirmParameter 到 Parameter,以支持更多的场景
- 优化:优化 HumanMessage 类的函数处理逻辑
- 优化: 重构 Chain 的验证逻辑
- 优化:优化 AiMessageResponse.getFunctionCallers 方法
- 优化:优化 getNodeContext 方法,只需要传入 id 值
- 优化:移除 Moonshot ,使用 openai 替代
- 优化:优化 parent 和 children 的过度设计,使之逻辑更加简洁
- 修复:修复 Node 包含子的 chain 时,会导致 json 解析错误的问题
- 修复:多轮 function call 时,获取最后一条 HumanMessage 错误的问题
- 修复:Chain 的 Parameter 类型为 Array 时,内容固定值无法解析的问题
- 修复: 修复 Parameter 为非必填,但是也必须输入参数的问题
- 修复: 在 js 执行节点可能出现 java.lang.NoClassDefFoundError: com/ibm/icu/number/Notation 错误的问题
- 修复:正则表达式
Action Input: (\{.<em>?})
在匹配时会漏掉最后一个"}"
的问题,感谢 @狂野流星 - 修复:节点异步执行的情况下,可能出现 check 不正确的问题
- 修复:jsExecNode 无法转换结果为 JsonObject 的问题
- 修复:DeepseekLlm 无法自动注入,配置 factories 文件
源码下载

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
ng-zorro-antd 20.3.0 发布,基于 Angular 的 UI 组件
ng-zorro-antd 是 Ant Design 的 Angular 实现,主要用于研发企业级中后台产品。全部代码开源并遵循 MIT 协议,任何企业、组织及个人均可免费使用。 ng-zorro-antd20.3.0 正式发布,更新内容如下: Features carousel:新增nzArrows属性 (#9355) (1b9714b) check-list:清单项支持定义默认是否完成 (#9343) (235b493) i18n:provideNzI18n支持 factory function 作为参数 (#9393) (1371265) mention:新增nzClear属性 (#9377) (cbecebf) mention:新增nzVariant属性 (#9379) (d92568b) segmented:新增nzShape属性 (#9368) (ffce6c3) segmented:新增nzName属性并支持键盘交互 (#9373) (ebd8bdc) upload:nzBeforeUpload支持 promise 返回类型 (#9402) (cece107) Bug F...
-
下一篇
OpenAI 发布最大规模 ChatGPT 普通用户使用报告
OpenAI 经济研究团队与哈佛大学经济学家 David Deming 合作完成了名为《How people are using ChatGPT》的研究报告,据称这是有史以来最大规模的一次关于普通用户(consumer users)如何使用 ChatGPT 的调查。 样本包括 150 万条对话,结合了 ChatGPT 在 2025 年中期的用户活动数据(当时每周有约 7 亿活跃用户)。 下面是该研究的一些发现: 谁在使用 ChatGPT? 性别差距正在缩小。早期用户中,名字可分辨为“女性倾向”的占比曾比现在少;到了 2025 年 7 月,这一比例上升到超过一半。 在低收入和中等收入国家的采用率增长尤其快。到 2025 年 5 月,最低收入国家的增长率是最高收入国家的 4 倍以上。 人们用 ChatGPT 做什么? 大部分对话是关于处理日常任务(practical guidance)、获取信息(seeking information)和写作(writing)。写作是工作中最常见的任务类型。 互动类型可以分为三类:“Asking”(提问)、“Doing”(执行任务/创造输出)、“Expre...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7,8上快速安装Gitea,搭建Git服务器