SpringAI 函数工具调用

工具调用

工具调用(也称为函数调用)是 AI 应用中的一种常见模式,允许模型与一组 API 或工具交互,增强其功能。

工具调用作用:

  • 信息检索

    此类工具可用于从外部来源检索信息,例如数据库、网络服务、文件系统或网络搜索引擎。目标是增强模型的知识,使其能够回答它原本无法回答的问题。因此,它们可以在检索增强生成(RAG)场景中使用。例如,可以使用工具检索特定位置的当前天气、检索最新的新闻文章或查询数据库中的特定记录。

  • 执行操作

    例如发送电子邮件、在数据库中创建新记录、提交表单或触发工作流。目标是自动化原本需要人工干预或明确编程的任务。例如,可以使用工具为与聊天机器人互动的客户预订航班、填写网页上的表单,或在代码生成场景中根据自动化测试(TDD)实现 Java 类。

工具调用链路

example

go 复制代码
@RestController
publicclass ToolController {
    @Autowired
    ChatClient chatClient;

    @GetMapping("/toolcall")
    public String toolCall(@RequestParam("msg") String msg){
        String response = chatClient.prompt(msg)
                //.tools(new DateTimeTools())
                .call()
                .content();
        return response;
    }

}

不加工具调用情况下:

自定义获取日期的函数:

go 复制代码
public class DateTimeTools {

    @Tool(description = "今天是几号以及时间的时区")
    String getCurrentDateTime() {
       String response=  LocalDateTime.now().atZone(LocaleContextHolder.getTimeZone().toZoneId()).toString();
        System.out.println("getCurrentDateTime:"+response);
        return response;
    }
}

自定义发送邮件函数工具

go 复制代码
@Tool(description = "发送邮件")
    String SendEmail(String mailText) {
        // 邮箱配置信息(替换为实际值)
        String host = "smtp.163.com";       // SMTP服务器
        String username = "from@163.com"; // 邮箱账号
        String password = "授权码";      // 邮箱授权码(非登录密码!)
        String toAddress = "to@163.com"; // 收件人

        // 邮件属性配置
        Properties props = new Properties();
        props.put("mail.smtp.host", host);
        props.put("mail.smtp.port", "465"); // SSL端口
        props.put("mail.smtp.auth", "true"); // 需要认证
        props.put("mail.smtp.ssl.enable", "true"); // 启用SSL
        props.put("mail.debug", "true"); // 调试模式(可选)

        // 创建会话
        Session session = Session.getInstance(props, new Authenticator() {
            @Override
            protected PasswordAuthentication getPasswordAuthentication() {
                returnnew PasswordAuthentication(username, password);
            }
        });
        try {
            // 创建邮件
            Message message = new MimeMessage(session);
            message.setFrom(new InternetAddress(username)); // 发件人
            message.setRecipient(Message.RecipientType.TO, new InternetAddress(toAddress)); // 收件人
            message.setSubject("SpringAI测试主题"); // 主题
            message.setText("SpringAI:"+mailText); // 纯文本内容
            // 发送邮件
            Transport.send(message);
            System.out.println("邮件发送成功!");

        } catch (MessagingException e) {
            e.printStackTrace();
            System.err.println("邮件发送失败: " + e.getMessage());
        }
        return"发送邮件成功";
    }

function作为tool进行调用

定义一个function

go 复制代码
public class WeatherService  implements Function<WeatherRequest,WeatherResponse> {
    public WeatherResponse apply(WeatherRequest request) {
        return new WeatherResponse(23.0, Unit.C);
    }
}
public enum Unit {C, F}
public record WeatherRequest(String location, Unit unit) {}
public record WeatherResponse(double temp, Unit unit) {}

定义toolcallback和调用

go 复制代码
@GetMapping("/functionCall")
    public String functionCall(@RequestParam("msg") String msg){
        //定义toolCallback
        ToolCallback toolCallback = FunctionToolCallback
                .builder("currentWeather", new WeatherService())
                .description("获取当地的天气")
                .inputType(WeatherRequest.class)
                .build();
        //调用
        String response = chatClient.prompt(msg)
                .tools(toolCallback) //调用函数
                .call()
                .content();
        return response;
    }
相关推荐
央链知播18 小时前
双轮驱动 六方协同--“可信资产IPO+数链金融RWA“链改2.0深圳共识发布
microsoft·金融
Liquad Li19 小时前
Azure Data Factory (ADF) vs Azure Logic Apps: 对比分析
microsoft·azure
Liquad Li19 小时前
Azure Logic App 与 Azure Function 对比分析
microsoft·azure
爱睡觉的圈圈19 小时前
突破反爬限制:动态IP轮换策略与实现
windows·tcp/ip·microsoft
fdc201719 小时前
Avalonia:使用附加属性实现命令与事件的绑定
javascript·windows·microsoft
kyle~2 天前
Qt---对话框QDialog
数据库·qt·microsoft
偷心伊普西隆2 天前
EXCEL VBA 清空Excel工作表(Sheet)的方法
microsoft·excel
一点都不方女士3 天前
《无畏契约》游戏报错“缺少DirectX”?5种解决方案(附DirectX修复工具)
windows·游戏·microsoft·动态链接库·directx·运行库
anlpsonline3 天前
安全产业 出海行动 | 安贝斯受邀参加第六届非传统安全(杭州)国际论坛:靠近国际前沿 拓宽国际视野
microsoft
seegaler4 天前
WrenAI:开源革命,重塑商业智能未来
人工智能·microsoft·ai