LangChain4j 的 Low 和 High 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);
    }
}
相关推荐
IT_陈寒4 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
淇奥75 小时前
【MyBatis-Plus】MyBatis-Plus 学习笔记
后端
_code_bear_5 小时前
OpenSpec CLI 与 OPSX 工作流说明
前端·后端·架构
用户8356290780515 小时前
使用 Python 在 PowerPoint 中添加并控制音频播放
后端·python
用户8356290780515 小时前
使用 Python 在 PowerPoint 中生成并自定义饼图与环形图
后端·python
念何架构之路6 小时前
Go语言常见并发模式
开发语言·后端·golang
Cosolar6 小时前
大模型应用开发面试 • 第4期|A2A、复杂挑战与具身智能
人工智能·后端·面试
迷渡6 小时前
聊一聊 Bun 用 Rust 重写这件事
开发语言·后端·rust
王中阳Go6 小时前
秒杀、分库分表、全链路追踪:一个电商微服务的架构全拆解
后端·go
正儿八经的少年6 小时前
Spring Boot 两种激活配置方式的作用与区别
java·spring boot·后端