国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

太強(qiáng)了!Spring AI調(diào)用本地函數(shù),實(shí)時(shí)獲取最新數(shù)據(jù)

開(kāi)發(fā) 前端
Spring AI 為從函數(shù)指定工具提供了內(nèi)置支持,內(nèi)部會(huì)將一個(gè)函數(shù)式類型(Function、Supplier、Consumer 或 BiFunction)轉(zhuǎn)換為一個(gè)工具。

環(huán)境:SpringBoot3.4.2

1. 簡(jiǎn)介

當(dāng)我們問(wèn)大模型當(dāng)前的天氣情況時(shí),它通常是無(wú)法直接給出準(zhǔn)確答案的。如下示例,我們通過(guò)阿里的 "qwen-turbo" 模型問(wèn)當(dāng)前天氣情況時(shí),輸出的結(jié)果如下:

圖片圖片

在這種情況下,如果大模型被設(shè)計(jì)為能夠與外部工具進(jìn)行交互(即工具調(diào)用),它就可以請(qǐng)求一個(gè)專門用于天氣查詢的工具來(lái)獲取當(dāng)前的天氣情況。然后,模型可以處理這個(gè)工具返回的數(shù)據(jù),并以自然語(yǔ)言的形式將天氣信息傳達(dá)給我們。

函數(shù)調(diào)用(Spring AI中已改為工具調(diào)用)是AI應(yīng)用中的一種常見(jiàn)模式,它允許模型與一組API或工具進(jìn)行交互,從而增強(qiáng)其能力。

工具主要用于以下兩個(gè)方面:

  • 信息檢索:此類別的工具可用于從外部源(如數(shù)據(jù)庫(kù)、網(wǎng)絡(luò)服務(wù)、文件系統(tǒng)或網(wǎng)頁(yè)搜索引擎)檢索信息。其目標(biāo)是增強(qiáng)模型的知識(shí)儲(chǔ)備,使其能夠回答原本無(wú)法回答的問(wèn)題。因此,它們可以用于檢索增強(qiáng)生成(RAG)場(chǎng)景。例如,可以使用工具檢索給定位置的當(dāng)前天氣、查詢數(shù)據(jù)庫(kù)中的特定記錄。
  • 執(zhí)行操作:此類別的工具可用于在軟件系統(tǒng)中執(zhí)行操作,如發(fā)送電子郵件、在數(shù)據(jù)庫(kù)中創(chuàng)建新記錄、提交表單或觸發(fā)工作流。其目標(biāo)是自動(dòng)化那些原本需要人工干預(yù)或明確編程的任務(wù)。例如,可以使用工具為與聊天機(jī)器人交互的客戶預(yù)訂航班、填寫網(wǎng)頁(yè)上的表單等等。

Spring AI提供了便捷的API來(lái)定義工具、解析來(lái)自模型的工具調(diào)用請(qǐng)求并執(zhí)行工具調(diào)用。如下圖是函數(shù)調(diào)用(工具調(diào)用)在整個(gè)問(wèn)答流程中的調(diào)用原理:

The main sequence of actions for tool callingThe main sequence of actions for tool calling

接下來(lái),我們將通過(guò)2個(gè)示例來(lái)講解如何通過(guò)Spring AI的工具調(diào)用(函數(shù)調(diào)用)來(lái)增強(qiáng)大模型的輸出能力。

2. 實(shí)戰(zhàn)案例

2.1 環(huán)境準(zhǔn)備

<dependency>
  <groupId>com.alibaba.cloud.ai</groupId>
  <artifactId>spring-ai-alibaba-starter</artifactId>
  <version>1.0.0-M6.1</version>
</dependency>

配置如下:

spring:
  ai:
    dashscope:
      api-key: sk-0c06a5b215********d6250417
      base-url: https://dashscope.aliyuncs.com/compatible-mode/v1
      chat:
        options:
          model: qwen-turbo

我們使用阿里的大模型 "qwen-turbo" 。

2.2 獲取當(dāng)前時(shí)間

首先,我們編寫如下的接口,獲取當(dāng)前的時(shí)間。

@RestController
@RequestMapping("/tools")
public class ToolController {
  private final ChatClient chatClient ;
  public ToolController(ChatClient.Builder aiClientBuilder) {
    this.chatClient = aiClientBuilder.build() ;
  }
  
  @GetMapping("/getDate")
  public ResponseEntity<?> getDate(String prompt) {
    String response = this.chatClient
        .prompt(prompt)
        .call().content() ;
    return ResponseEntity.ok(response) ;
  }
}

我們先直接訪問(wèn)該接口,如下:

圖片

無(wú)法回答當(dāng)前時(shí)間,接下來(lái),我們通過(guò)定義本地的工具來(lái)增強(qiáng)模型的輸出能力。

public class DateTimeTools {


  @Tool(description = "獲取用戶時(shí)區(qū)中的當(dāng)前日期和時(shí)間")
  String getCurrentDateTime() {
    System.err.println("DateTimeTools被調(diào)用了") ;
    return LocalDateTime.now()
      .atZone(LocaleContextHolder.getTimeZone().toZoneId())
      .toString() ;
  }
}

@Tool 注解說(shuō)明:

  • name:工具的名稱。如果未提供,將使用方法名作為工具名稱。AI模型在調(diào)用工具時(shí)會(huì)使用這個(gè)名稱來(lái)識(shí)別它。因此,在同一個(gè)類中不允許有兩個(gè)具有相同名稱的工具。對(duì)于特定的聊天請(qǐng)求,該名稱必須在模型可用的所有工具中是唯一的。
  • description:工具的描述,模型可以使用這個(gè)描述來(lái)理解何時(shí)以及如何調(diào)用該工具。如果未提供,將使用方法名作為工具描述。但是,強(qiáng)烈建議提供一個(gè)詳細(xì)的描述,因?yàn)檫@對(duì)于模型理解工具的目的以及如何使用它至關(guān)重要。如果未能提供良好的描述,可能會(huì)導(dǎo)致模型在應(yīng)該使用工具時(shí)未使用,或者錯(cuò)誤地使用工具。
  • returnDirect:工具的結(jié)果是否應(yīng)該直接返回給客戶端,還是傳回給模型。
  • resultConverter:用于將工具調(diào)用的結(jié)果轉(zhuǎn)換為字符串對(duì)象(以便發(fā)送回AI模型)的ToolCallResultConverter實(shí)現(xiàn)。
     

下一步,我們需要將上面的工具添加到ChatClient中

@GetMapping("/getDate")
public ResponseEntity<?> getDate(String prompt) {
  String response = this.chatClient
    .prompt(prompt)
    .tools(new DateTimeTools())
    .call().content() ;
  return ResponseEntity.ok(response) ;
}

通過(guò)tools方法配置我們上面定義的工具,這里你可以設(shè)置多個(gè)工具。

如上配置后,我們接下來(lái)就可以請(qǐng)求了。

圖片

圖片

正確的輸出了結(jié)果,通過(guò)控制臺(tái)的輸出也說(shuō)明調(diào)用了我們本地配置的工具(函數(shù))。

2.3 獲取天氣情況

接下來(lái),我們?cè)俣x一個(gè)工具,該工具用來(lái)訪問(wèn)天氣情況。該工具要求接收一個(gè)參數(shù),將會(huì)根據(jù)輸入?yún)?shù)中的地理位置獲取當(dāng)前的天氣。

public class WeatherTools {
 
  @Tool(description = "獲取當(dāng)前天氣預(yù)報(bào)")
  String getCurrentWeather(String city) {
    RestClient client = RestClient.create(
      URI.create("https://api.vvhan.com")) ;
    Map<?, ?> result = client.get()
        .uri("/api/weather?city={0}", city)
        .retrieve()
        .body(Map.class) ;
    try {
      return new ObjectMapper().writeValueAsString(result) ;
    } catch (JsonProcessingException e) {
      throw new RuntimeException(e) ;
    }
  }
}

這里非常的簡(jiǎn)單,我們通過(guò)RestTemplate來(lái)請(qǐng)求API接口獲取天氣情況。

配置工具

@GetMapping("/weather")
public ResponseEntity<String> getCurrentWeather(String prompt) {
  String response = this.chatClient
    .prompt(prompt)
    .tools(new WeatherTools())
    .call().content() ;
  return ResponseEntity.ok(response) ;
}

請(qǐng)求該接口

圖片

成功獲取到了天氣情況

我們還可以將參數(shù)構(gòu)造為對(duì)象類型,如下示例:

// 請(qǐng)求參數(shù)
public record WeatherRequest(@ToolParam(description = "城市", required = true) String city) {
}
// 響應(yīng)結(jié)果
public record WeatherResponse(String info) {
}

工具定義

@Tool(description = "獲取當(dāng)前天氣預(yù)報(bào)")
WeatherResponse getCurrentWeather(WeatherRequest request) {
  RestClient client = RestClient.create(URI.create("https://api.vvhan.com")) ;
  Map<?, ?> result = client.get()
      .uri("/api/weather?city={0}", request.city())
      .retrieve()
      .body(Map.class) ;
  return new WeatherResponse(new ObjectMapper().writeValueAsString(result)) ;
}

2.4 使用函數(shù)作為工具

Spring AI 為從函數(shù)指定工具提供了內(nèi)置支持,內(nèi)部會(huì)將一個(gè)函數(shù)式類型(Function、Supplier、Consumer 或 BiFunction)轉(zhuǎn)換為一個(gè)工具。

我們可以將任何 Function、Supplier、Consumer 或 BiFunction bean 用作工具。bean 的名稱將用作工具的名稱,并且可以使用 Spring 中的 @Description 注解為工具提供描述,該描述由模型使用,以了解何時(shí)以及如何調(diào)用工具。

函數(shù)的輸入和輸出可以是 Void 或 POJO(Plain Old Java Object,簡(jiǎn)單的 Java 對(duì)象)。輸入和輸出的 POJO 必須是可序列化的,因?yàn)榻Y(jié)果將被序列化并發(fā)送回模型。函數(shù)以及輸入和輸出類型都必須是public的。

我們這里還是以獲取天氣為例講解,如何使用:

public static final String CURRENT_WEATHER = "currentWeather" ;
@Bean(CURRENT_WEATHER)
@Description("獲取當(dāng)前天氣預(yù)報(bào)")
Function<WeatherRequest, WeatherResponse> currentWeather() {
  RestClient client = RestClient.create(
    URI.create("https://api.vvhan.com")) ;
  return city -> {
    String result = client.get()
      .uri("/api/weather?city={0}", city)
      .retrieve()
      .body(String.class) ;
    return new WeatherResponse(result) ;
  } ;
}

注冊(cè)工具

@GetMapping("/weather")
public ResponseEntity<String> getCurrentWeather(String prompt) {
  String response = this.chatClient
    .prompt(prompt)
    // 這里是我們的beanName
    .tools(WeatherTools.CURRENT_WEATHER)
    .call().content() ;
  return ResponseEntity.ok(response) ;
}

調(diào)用結(jié)果

圖片圖片


責(zé)任編輯:武曉燕 來(lái)源: Springboot實(shí)戰(zhàn)案例源碼
相關(guān)推薦

2025-01-13 13:47:13

2025-01-22 14:02:35

2025-08-07 09:30:57

2025-09-01 02:00:00

2025-02-08 08:00:00

JavaDeepSeekIDEA

2022-05-30 16:31:08

CSS

2025-05-14 01:00:00

Spring工具工廠類

2021-03-04 09:31:42

開(kāi)源技術(shù) 項(xiàng)目

2025-03-26 08:28:36

2022-01-26 07:18:57

ES6WeakSetMap

2025-07-02 08:00:00

防抖SpringBoot開(kāi)發(fā)

2023-12-10 20:33:50

Redis搜索全文

2021-08-05 16:25:37

Windows 11Windows微軟

2022-06-08 08:01:28

模板字面量類型

2024-01-30 09:21:29

CSS文字效果文字裝飾

2025-11-03 06:25:26

SpringJSONJackson

2025-04-10 00:25:00

Spring@JsonView注解

2025-06-26 01:22:00

SpringBean開(kāi)發(fā)

2023-10-17 08:55:08

數(shù)據(jù)庫(kù)數(shù)據(jù)業(yè)務(wù)

2021-02-03 20:19:08

Istio流量網(wǎng)格
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

97久久综合区小说区图片区| 视频在线一区二区三区| 亚洲爱爱爱爱爱| 超碰在线人人爱| 日韩国产成人精品| 不卡av电影在线观看| 国产高清视频在线播放| 国产日韩欧美制服另类| 亚洲成人第一| 欧美精品激情| 日本精品免费一区二区三区| 成人小电影网站| 婷婷亚洲久悠悠色悠在线播放| a级片国产精品自在拍在线播放| 欧美国产亚洲另类动漫| 精品国免费一区二区三区| 91豆麻精品91久久久久久| 一本色道久久综合亚洲二区三区| 精品日韩一区二区| 在线亚洲电影| 亚洲欧洲国产日韩| 北条麻妃在线观看| 国产久卡久卡久卡久卡视频精品| 国产视频精品网| 亚洲色图国产| 国产精品99蜜臀久久不卡二区 | 色女孩综合网| 影音先锋日韩精品| 黄色网址在线免费观看| 国产精品色呦呦| 男人的天堂狠狠干| 国产尤物一区二区在线| 一级日韩一区在线观看| 奇米色777欧美一区二区| 欧美一区二区三区电影在线观看 | 国产精品成人自拍| 日韩在线免费视频| 国产精品66| 日韩在线免费高清视频| 亚洲成人va| 最新国产精品亚洲| 95精品视频| 久久69精品久久久久久久电影好| 中韩乱幕日产无线码一区| 亚洲午夜精品视频| 日韩免费小视频| 中文字幕亚洲欧美| 国产精品成人**免费视频| 日韩在线观看av| 视频在线亚洲| 91国内产香蕉| 日韩精品影视| 国产精品一区二区免费| 国产亚洲激情| 亚洲一区精彩视频| 成人黄页在线观看| free亚洲| 色欲综合视频天天天| 超碰在线caoporn| 亚洲人成网站免费播放| 国产一区二区三区免费在线| 欧美黑人一区二区三区| 国产中文字幕一区二区三区| 国产日韩av在线| 小嫩嫩精品导航| 国产成人一二三区| 国产精品看片你懂得| 中文字幕网在线| 日韩欧美一区中文| 麻豆一二三区精品蜜桃| 国产精品亚洲精品| 午夜在线精品| 国自产拍偷拍精品啪啪一区二区| 国产欧美va欧美不卡在线| 在线播放av片| 亚洲国产成人一区| 伦理一区二区三区| 国产精品一区二| caoporm超碰国产精品| 亚洲精品一区二区| 精品播放一区二区| 狠狠一区二区三区| 国产精品9999久久久久仙踪林| 日韩制服丝袜先锋影音| 日本在线观看a| 欧美视频中文在线看| 欧美日韩在线观看首页| 国产91精品久久久久久| 久久久蜜桃一区二区人| 成人在线激情网| 欧美日韩二区三区| 激情中国色综合| 国产热re99久久6国产精品| 免费xxxx性欧美18vr| 涩涩视频免费网站| 亚洲精品一区二区三区影院| 米奇精品关键词| 在线日韩av永久免费观看| 亚洲视频一区在线观看| 呦呦在线视频| 欧美性做爰毛片| 久久国产视频网| 最新在线地址| 日韩在线中文视频| 亚洲免费成人| 激情五月色综合亚洲小说| 制服丝袜av成人在线看| 9l亚洲国产成人精品一区二三| 91久久精品国产91久久| 精品国产精品国产偷麻豆| 久久av综合网| 日韩毛片在线看| 日本不卡在线视频| 九色视频网站| 精品激情国产视频| 99久久免费国产| 国产啊啊啊视频在线观看| 亚洲成人在线视频网站| 国产日韩欧美中文在线播放| 另类人妖一区二区av| 日韩性感在线| 成人啪啪免费看| 欧美巨大另类极品videosbest | 性综艺节目av在线播放| 欧美成人激情免费网| 欧美一级色片| 男同互操gay射视频在线看| 日本韩国一区二区三区| 精品五月天堂| 久久国产精品网| 亚洲大胆人体在线| 午夜精品视频| 一级毛片国产| 97在线视频国产| 不卡区在线中文字幕| 污污网站在线观看| 97久久精品午夜一区二区| 中文字幕一区二区不卡| 激情久久一区二区| 精品久久久无码人妻字幂| 日韩一级大片在线| 在线日本成人| 你懂的视频在线观看| 日韩免费在线看| 国产精品区一区二区三区| 日韩午夜视频在线| 国产一线二线三线女| 日韩精品免费在线视频观看| 在线精品亚洲| 国产天堂素人系列在线视频| 成人黄色免费在线观看| 亚洲伦理在线精品| 小说区图片区色综合区| 亚洲精品高清无码视频| 九九视频直播综合网| 91老师片黄在线观看| 四虎精品在线观看| 无码人妻精品一区二区三区在线| 亚洲人成五月天| 日韩精品一区二区三区免费视频| 亚洲尤物在线视频| 国产免费一区二区三区| 全亚洲最色的网站在线观看| 日韩精品一区二区久久| 国产传媒久久久| 国产一级做a爰片久久| 97影院秋霞午夜在线观看| 高端美女服务在线视频播放| 高清视频在线观看三级| 人猿泰山h版在线观看| 国产美女视频一区二区三区| 最新精品视频在线| 国内福利写真片视频在线 | 5月丁香婷婷综合| 国产精品视频免费观看www| 国产精品网址在线| 欧美一区二区福利| 黄色国产精品视频| av在线免费观看网| wwwav91| 成人黄色视屏网站| 大型av综合网站| 本田岬高潮一区二区三区| 午夜电影久久久| 欧美成年人视频网站| 97超碰人人爱| 在线视频中文字幕| 欧美在线导航| 蜜乳av另类精品一区二区| 亚洲成人aaa| 日韩av电影国产| 成人午夜影院在线观看| 日b视频免费观看| 亚洲一区二区三区精品中文字幕 | 色婷婷狠狠五月综合天色拍| 91亚洲精品乱码久久久久久蜜桃 | 亚洲精品成人天堂一二三| 欧美日本国产在线| 亚洲精品欧美极品| 亚洲精品国产一区|