当前位置: 首页 > news >正文

Spring AI Alibaba 的 ChatClient 工具注册与 Function Calling 实践

Spring AI Alibaba 的 ChatClient 工具注册与 Function Calling 实践总结

在实际使用 Spring AI 进行聊天应用开发时,碰到工具(Tool)注册、函数调用(Function Calling)以及
ChatClient 配置
的问题。本文将总结从源码到实践的一些经验和知识点,帮助你更高效地集成 AI 聊天功能。


1. ChatClient Builder 的核心方法

Spring AI 提供了ChatClient.Builder,用于构建一个可用的 AI 聊天客户端。常用方法包括:

  • 默认系统提示
.defaultSystem(AiPrompts.GENERAL_ASSISTANT)
  • 默认会话记忆顾问
.defaultAdvisors(MessageChatMemoryAdvisor.builder(MessageWindowChatMemory.builder().chatMemoryRepository(chatMemoryRepository).build()).build())
  • 工具注册
.defaultTools(...)// 注册对象实例.defaultToolNames(...)// 注册 Spring Bean 名称对应的工具.tool(...)// 注册 @Tool 注解方法

注意:.defaultTools().defaultToolNames()的作用不同,稍后详细说明。


2. Function Calling 与工具注册

Spring AI 支持把 Spring Bean 自动注册为 AI 可调用的函数(function calling)。常用方式有两种:

2.1 Bean + Supplier / Function

@Bean@Description("查询所有学生信息")publicSupplier<List<Student>>getAllStudents(){return()->studentInfoService.selectStudentInfoList(newStudent());}@Bean@Description("根据学生ID查询学生信息")publicFunction<Long,Student>getStudentById(){returnstudentId->studentInfoService.selectStudentInfoByStudentId(studentId);}
  • Supplier:无入参,返回值为工具输出。
  • Function<T, R>:有入参T,返回值为工具输出R
  • 通过.defaultToolNames("getAllStudents")自动注册,AI 可以直接调用。

2.2 @Tool 注解方法

@Tool(name="getAllStudents",description="查询所有学生信息")publicList<Student>getAllStudents(){returnstudentInfoService.selectStudentInfoList(newStudent());}
  • 适用于更标准的 function calling 方式
  • 需要使用.defaultTools()注册

3..defaultTools().defaultToolNames()区别

方法适用场景注意点
.defaultTools(Object... tools)注册对象实例(Lambda、工具对象)如果 Lambda 没有@Tool注解,会报错 “No @Tool annotated methods found”,需要使用.toolCallbacks()
.defaultToolNames(String... beanNames)自动注册 Spring 上下文中 Bean 名称对应的工具只能识别 Bean 名称对应的 Supplier / Function 或@Tool方法
.toolCallbacks()注册@Tool注解方法或ToolCallback支持标准 function-calling

✅ 结论:

  • Supplier / Function Bean → 推荐.defaultToolNames()
  • 普通方法 + @Tool 注解 →.defaultTools()

4. 自动收集 Bean 注册工具

在实际项目中,如果工具数量较多,不希望手动写.defaultToolNames(...),可以通过循环自动收集:

Map<String,Supplier>supplierBeans=applicationContext.getBeansOfType(Supplier.class);Map<String,Function>functionBeans=applicationContext.getBeansOfType(Function.class);Set<String>allToolNames=supplierBeans.keySet().stream().collect(Collectors.toSet());allToolNames.addAll(functionBeans.keySet());ChatClientclient=ChatClient.builder(chatModel).defaultSystem("你是智能助手").defaultAdvisors(...).defaultToolNames(allToolNames.toArray(newString[0])).build();
  • 自动扫描 Spring 上下文的所有 Supplier / Function Bean
  • 避免手动列出工具名称
  • 保持 ChatClient 配置简洁

5. Supplier 与 Function 区别

类型参数返回值使用场景
Supplier<R>R无输入参数工具,直接返回结果
Function<T, R>TR需要输入参数的工具,例如根据 ID 查询对象

示例:

Supplier<List<Student>>getAllStudents;// 无入参Function<Long,Student>getStudentById;// 入参为学生ID


本文记录于 MindCampus 毕设项目开发过程中,2024年12月,如果对你有帮助不妨留一个赞

http://www.cnnetsun.cn/news/20840.html

相关文章:

  • 如何5分钟搭建跨平台窗口监控系统:终极工具完全指南
  • NotchDrop:让MacBook刘海变身智能文件中转站
  • 5亿参数改写边缘智能规则:腾讯Hunyuan-0.5B-Instruct轻量化模型深度解析
  • 如何快速解决Nacos数据库升级冲突:5个实用技巧
  • 高密度互连板层压创新:从任意层互连到微孔填充技术
  • 高频PCB层压材料进化:介电性能博弈
  • 3.6万专业观众+50+采购团 CES Asia2026破解创新产品市场对接难题
  • B站漫画下载终极指南:一键搞定海量漫画本地化管理
  • 基于SpringBoot+vue的华强北商城二手手机管理系统
  • 20、音频插件与视频播放的技术实现
  • 贝锐携手中兴!星云MAX内置蒲公英异地组网,路由器变身私有云枢纽
  • 虚拟机性能优化实战指南
  • Blender 必备插件深度推荐:全面提升建模、动画、渲染效率的专业工具集(适用于 Blender 5.0)
  • 面部表情识别终极指南:5分钟快速部署PyTorch深度学习系统
  • 稳定性(二):ANR
  • Spark-TTS实战指南:零基础搭建智能语音合成系统
  • 用n8n打造自愈型用例库与质量知识图谱
  • WMS:仓库的“智能机器人指挥官”——现代仓储革命性的空间与时间管理者
  • 压缩机的精准客户群体都有哪些?
  • Topit窗口置顶神器:彻底告别Mac多任务窗口遮挡烦恼
  • 创客匠人峰会洞察:IP 信任为基,AI 效率为翼,知识变现的可持续增长模型
  • Open XML SDK:企业级文档自动化解决方案的战略价值分析
  • 2、脚本编程之旅:从基础到实践
  • RoslynPad 跨平台 C 编辑器:从入门到精通的实用指南
  • SSDTTime:ACPI热补丁技术的智能解决方案
  • 继电器:电力安全的隐形守护者
  • R.swift终极配置指南:构建强类型资源管理系统的完整实践
  • 联邦学习赋能YOLOv5:计算机视觉的隐私保护新范式
  • 从卡顿到丝滑:我的酷安桌面化使用体验
  • kmp算法