用 solon-ai 写个简单的 deepseek 程序(构建全国产 ai 智能体应用)

用国产应用开发框架(及生态),对接国产 ai。构建全国产 ai 智能体应用。

1、先要申请个 apiKey

打开 https://www.deepseek.com 官网,申请个 apiKey 。(一万字略过)

2、试试:Hello deepseek

用 solon-initializr (https://solon.noear.org/start/),生成一个 solon-web 模板项目。之后:

  • 在应用属性里添加配置(app.yml)
yaml 复制代码
solon.ai.chat:
  deepseek:
    apiUrl: "https://api.deepseek.com/v1/chat/completions" # 使用完整地址(而不是 api_base)
    apiKey: "sk-9f4415ddc57049658189************"  # 填写自己申请的 apiKey
    model: "deepseek-chat"
  • 用配置器类构建通用聊天模型
java 复制代码
@Configuration
public class DeepseekConfig {
    @Bean
    public ChatModel chatModel(@Inject("${solon.ai.chat.deepseek}") ChatConfig config) {
        return ChatModel.of(config).build();
    }
}
  • 添加测试用的控制器
java 复制代码
@Controller
public class DemoController {
    @Inject
    ChatModel chatModel;

    @Mapping("hello")
    public String hello(String message) throws IOException {
        return chatModel.prompt(message).call().getMessage().getContent();
    }
}
  • 测试一下

启动项目。打开浏览器地址:http://localhost:8080/hello?message=hello。效果良好:

3、尝试把输出改成 sse,方便打字效果的聊天窗口开发

这里需要添加两个插件依赖,协助流式输出 sse 数据。

插件 作用
org.noear:solon-web-rx 提供响应式输出(就是流式输出)
org.noear:solon-web-sse 提供sse渲染支持

加好依赖后,只需要改进下控制器的几行代码:

java 复制代码
@Controller
public class DemoController {
    @Inject
    ChatModel chatModel;

    @Produces(MimeType.TEXT_EVENT_STREAM_UTF8_VALUE) //这个很重要,申明用 sse 格式渲染
    @Mapping("hello")
    public Flux<String> hello(String message) throws IOException {
        return Flux.from(chatModel.prompt(message).stream())
                .filter(resp -> resp.hasChoices())
                .map(resp -> resp.getMessage().getContent());
    }
}
  • 测试一下

启动项目。再次打开浏览器地址:http://localhost:8080/hello?message=hello。效果良好:

4、现在开始 RAG,以 "联网搜索" 作为知识库

这里把"联网搜索",做为一个知识库使用(内部是动态搜索的)。用它作为 RAG 的外部检索支持。

  • 应用属性加一块配置
yaml 复制代码
solon.ai.chat:
  deepseek:
    apiUrl: "https://api.deepseek.com/v1/chat/completions" # 使用完整地址(而不是 api_base)
    apiKey: "sk-9f4415ddc57049658189************"  # 填写自己申明的 apiKey
    model: "deepseek-chat"
    
solon.ai.repo:
  websearch:
    apiUrl: "https://api.bochaai.com/v1/web-search" # 使用完整地址(而不是 api_base)
    apiKey: "sk-demo..."
  • 配置器类也调整下
java 复制代码
@Configuration
public class DeepseekConfig {
    @Bean
    public ChatModel chatModel(@Inject("${solon.ai.chat.deepseek}") ChatConfig config) {
        return ChatModel.of(config).build();
    }
    
    @Bean
    public Repository repository(@Inject("${solon.ai.repo.websearch}") AiConfig config,) {
        return new WebSearchRepository(config);
    }
}
  • 再改改控制器(输出重新写回简单的方式,不然不好截图)
java 复制代码
@Controller
public class DemoController {
    @Inject
    ChatModel chatModel;

    @Inject
    Repository repository;

    @Mapping("hello")
    public String hello(String message) throws IOException {
        //检索
        List<Document> context = repository.search(new QueryCondition(message).limit(4));

        //消息增强
        ChatMessage chatMessage = UserMessage.augment(message, context);

        //提交大模型并简单返回(不然,截图不好截)
        return chatModel.prompt(chatMessage).call().getMessage().getContent();
    }
}
  • 测试一下

启动项目。打开浏览器地址:http://localhost:8080/hello?message=solon%20%E6%98%AF%E8%B0%81%E5%BC%80%E5%8F%91%E7%9A%84%EF%BC%9F。效果良好:

相关推荐
用户40315986396631 分钟前
表达式并发计算
java·算法
SimonKing13 分钟前
告别System.currentTimeMillis()!Java高精度计时最佳实践
java·后端·程序员
Dcs13 分钟前
JUnit 5架构如何用模块化颠覆测试框架?
java
肉肉不想干后端17 分钟前
gRPC服务架构整合springboot部署实践指南
java
天天摸鱼的java工程师34 分钟前
volatile关键字实战指南:八年Java开发者详解五大应用场景
java·后端
刃神太酷啦44 分钟前
C++ 多态详解:从概念到实现原理----《Hello C++ Wrold!》(14)--(C/C++)
java·c语言·c++·qt·算法·leetcode·面试
wjm0410061 小时前
C++后端面试八股文
java·c++·面试
都叫我大帅哥1 小时前
📉 MySQL索引罢工事件簿:揭秘失效原因与优化起义方案
java·mysql
Seven971 小时前
剑指offer-11、⼆进制中1的个数
java