LangChain4j Low 和 Hight-level API

Low level API 和 High level API

Langchain4j 提供了两种抽象层次的 API:

  • Low level API:底层 API,可以最大自由程度地去访问所有底层组件,如 ChatModel、UserMessage、AiMessage、EmbeddingStore、Embedding 等。
  • High level API:高级 API,可以使用高级 API 服务(如 AiService)与 LLM 进行交互,这些 API 会隐藏所有复杂性的模板代码。当然,可以对模板代码进行适当的微调,但这一切都是以声明式方式完成的。

Low 和 High API 演示

Low

配置 LLMConfig

java 复制代码
@Configuration
public class LLMConfig {
    @Bean("qwen")
    public ChatModel chatModelQwen() {
        return OpenAiChatModel.builder()
                .apiKey(System.getenv("ALI_QWEN_API_KEY"))
                .modelName("qwen-plus")
                .baseUrl("https://dashscope.aliyuncs.com/compatible-mode/v1")
                .build();
    }
}

LowController

java 复制代码
@RestController
@RequestMapping("low")
public class LowController {
    @Resource(name = "qwen")
    private ChatModel chatModelQwen;

    @GetMapping("/qwen/getTokenUsage")
    public String helloQwen(@RequestParam(value = "question", defaultValue = "你是谁?") String question) {
        ChatResponse response = chatModelQwen.chat(UserMessage.from(question));
        String text = response.aiMessage().text();
        TokenUsage tokenUsage = response.tokenUsage();
        return String.format("[result] <br> %s <hr> [token usage] <br> %s", text, tokenUsage);
    }
}

注意 ChatResponse 这个对象。

ChatResponse 源码

java 复制代码
public class ChatResponse {
    ...
    protected ChatResponse(Builder builder) {
        this.aiMessage = (AiMessage)ValidationUtils.ensureNotNull(builder.aiMessage, "aiMessage");
        ChatResponseMetadata.Builder<?> metadataBuilder = ChatResponseMetadata.builder();
        if (builder.id != null) {
            validate(builder, "id");
            metadataBuilder.id(builder.id);
        }

        if (builder.modelName != null) {
            validate(builder, "modelName");
            metadataBuilder.modelName(builder.modelName);
        }

        if (builder.tokenUsage != null) {
            validate(builder, "tokenUsage");
            metadataBuilder.tokenUsage(builder.tokenUsage);
        }

        if (builder.finishReason != null) {
            validate(builder, "finishReason");
            metadataBuilder.finishReason(builder.finishReason);
        }

        if (builder.metadata != null) {
            this.metadata = builder.metadata;
        } else {
            this.metadata = metadataBuilder.build();
        }
    }
    ...
}

它封装了我们最常用的消息:

  • id 消息ID
  • modelName 模型名称
  • tokenUsage token 使用量
  • finishReason

High

定义 AI 服务接口 Service

java 复制代码
public interface Assistant {
    public String chat(String message);
}

实现 Assistant 的 Impl 实现类

java 复制代码
@Configuration
public class LLMConfig {
    @Value("${ai-api-key.deepseek}")
    private String deepseek;
	...
    @Bean
    public Assistant assistant(@Qualifier("qwen") ChatModel chatModelQwen) {
        // 替换传统的 ServiceImpl 实现类
        // 将 Service.class 的接口实现类交给 chatModel 模型来实现
        return AiServices.create(Assistant.class, chatModelQwen);
    }
}

HighController

java 复制代码
@RestController
@RequestMapping("high")
public class HighController {
    @Resource
    private Assistant assistant;

    @GetMapping("/qwen")
    public String hello(@RequestParam(value = "question", defaultValue = "你是谁?") String question) {
        return assistant.chat(question);
    }
}

https://juejin.cn/post/7606411170429599780

相关推荐
wxm63112 小时前
TCP监听--监听指定IP的端口号
java·网络·tcp/ip
csdn2015_12 小时前
java 把对象转化为json字符串
java·前端·json
想带你从多云到转晴12 小时前
03、数据结构与算法--单向链表
java·数据结构·算法
无籽西瓜a12 小时前
【西瓜带你学设计模式 | 第七期 - 适配器模式】适配器模式 —— 类适配器与对象适配器实现、优缺点与适用场景
java·后端·设计模式·软件工程·适配器模式
Oliver_LaVine12 小时前
idea启动后端项目-控制台中文乱码处理
java·ide
Flittly12 小时前
【SpringAIAlibaba新手村系列】(6)PromptTemplate 提示词模板与变量替换
java·spring boot·agent
yaaakaaang12 小时前
3.springboot,用eclipse轻松创建~
java·spring boot·eclipse
计算机学姐12 小时前
基于SpringBoot的新能源充电桩管理系统
java·vue.js·spring boot·后端·mysql·spring·java-ee
木井巳12 小时前
【笔试强训】Day1
java·算法
风萧萧199912 小时前
Milvus Java 快速入门
java·开发语言·milvus