冰河技术
导读
♻学习路线
  • 面试必问系列

    • 面试必问
  • 架构与模式

    • Java极简设计模式
    • 实战高并发设计模式
  • Java核心技术

    • Java8新特性
    • IOC核心技术
    • JVM调优技术
  • 容器化核心技术

    • Dockek核心技术
  • 分布式存储

    • Mycat核心技术
  • 数据库核心技术

    • MySQL基础篇
  • 服务器核心技术

    • Nginx核心技术
  • 渗透核心技术

    • 渗透实战技术
  • 底层技术
  • 源码分析
  • 基础案例
  • 实战案例
  • 面试
  • 系统架构
  • Spring6核心技术
  • 分布式事务

    • 分布式事务系列视频
  • SpringBoot
  • SpringCloudAlibaba
  • 🔥AI大模型项目

    • 一站式AI智能平台
    • AI智能客服系统
    • AI智能问答系统
    • 实战AI大模型
  • 中间件项目

    • 手写高性能Redis组件
    • 手写高性能脱敏组件
    • 手写线程池项目
    • 手写高性能SQL引擎
    • 手写高性能Polaris网关
    • 手写高性能RPC项目
  • 高并发项目

    • 分布式IM即时通讯系统(新)
    • 分布式Seckill秒杀系统
    • 实战高并发设计模式
  • 微服务项目

    • 简易电商脚手架项目
  • 手撕源码

    • 手撕Spring6源码
🌍知识星球
  • 总览

    • 《书籍汇总》
  • 出版图书

    • 《深入理解高并发编程:核心原理与案例实战》
    • 《深入理解高并发编程:JDK核心技术》
    • 《深入高平行開發:深度原理&專案實戰》
    • 《深入理解分布式事务:原理与实战》
    • 《MySQL技术大全:开发、优化与运维实战》
    • 《海量数据处理与大数据技术实战》
  • 电子书籍

    • 《实战高并发设计模式》
    • 《深入理解高并发编程(第2版)》
    • 《深入理解高并发编程(第1版)》
    • 《从零开始手写RPC框架(基础篇)》
    • 《SpringCloud Alibaba实战》
    • 《冰河的渗透实战笔记》
    • 《MySQL核心知识手册》
    • 《Spring IOC核心技术》
  • 关于自己
  • 关于学习
  • 关于职场
B站
Github
导读
♻学习路线
  • 面试必问系列

    • 面试必问
  • 架构与模式

    • Java极简设计模式
    • 实战高并发设计模式
  • Java核心技术

    • Java8新特性
    • IOC核心技术
    • JVM调优技术
  • 容器化核心技术

    • Dockek核心技术
  • 分布式存储

    • Mycat核心技术
  • 数据库核心技术

    • MySQL基础篇
  • 服务器核心技术

    • Nginx核心技术
  • 渗透核心技术

    • 渗透实战技术
  • 底层技术
  • 源码分析
  • 基础案例
  • 实战案例
  • 面试
  • 系统架构
  • Spring6核心技术
  • 分布式事务

    • 分布式事务系列视频
  • SpringBoot
  • SpringCloudAlibaba
  • 🔥AI大模型项目

    • 一站式AI智能平台
    • AI智能客服系统
    • AI智能问答系统
    • 实战AI大模型
  • 中间件项目

    • 手写高性能Redis组件
    • 手写高性能脱敏组件
    • 手写线程池项目
    • 手写高性能SQL引擎
    • 手写高性能Polaris网关
    • 手写高性能RPC项目
  • 高并发项目

    • 分布式IM即时通讯系统(新)
    • 分布式Seckill秒杀系统
    • 实战高并发设计模式
  • 微服务项目

    • 简易电商脚手架项目
  • 手撕源码

    • 手撕Spring6源码
🌍知识星球
  • 总览

    • 《书籍汇总》
  • 出版图书

    • 《深入理解高并发编程:核心原理与案例实战》
    • 《深入理解高并发编程:JDK核心技术》
    • 《深入高平行開發:深度原理&專案實戰》
    • 《深入理解分布式事务:原理与实战》
    • 《MySQL技术大全:开发、优化与运维实战》
    • 《海量数据处理与大数据技术实战》
  • 电子书籍

    • 《实战高并发设计模式》
    • 《深入理解高并发编程(第2版)》
    • 《深入理解高并发编程(第1版)》
    • 《从零开始手写RPC框架(基础篇)》
    • 《SpringCloud Alibaba实战》
    • 《冰河的渗透实战笔记》
    • 《MySQL核心知识手册》
    • 《Spring IOC核心技术》
  • 关于自己
  • 关于学习
  • 关于职场
B站
Github
  • 开篇:专栏介绍

    • 开篇:一站式AI智能平台正式开撸
  • 第01部分:需求设计

    • 第01节:总体需求与方案设计
  • 第02部分:后端实现

    • 第01节:整体项目结构搭建与说明
    • 第02节:实时流式聊天功能的设计与实现
    • 第03节:生成营销文案功能的设计与实现
    • 第04节:智能代码生成功能的设计与实现
    • 第05节:智能问答功能的设计与实现
    • 第06节:通用聊天功能的设计与实现
  • 第03部分:前端实现

    • 第01节:前端页面的设计与实现
  • 第04部分:专栏总结

    • 总结:一站式AI智能平台整体专栏总结

《一站式AI智能平台》后端系统实现-第06节:通用聊天功能的设计与实现

作者:冰河
星球:http://m6z.cn/6aeFbs
博客:https://binghe.site
文章汇总:https://binghe.site/md/all/all.html
源码获取地址:https://t.zsxq.com/0dhvFs5oR

沉淀,成长,突破,帮助他人,成就自我。

  • 本章难度:★★☆☆☆
  • 本章重点:对一站式AI智能平台的通用聊天功能进行设计与实现,从全局角度掌握一站式AI智能平台的整体项目结构。重点掌握一站式AI智能平台的通用设计思路和设计方法,并能够将其灵活应用到自身实际项目中。

大家好,我是冰河~~

一站式AI智能平台在设计和实战上主打一个实用,如果自己开发和搭建一套AI智能平台,并且应用于实际学习和工作场景,那将会是一件非常了不起的事情。

截止到目前,对于一站式AI智能平台的后端服务来说,我们设计和实现了实时流式聊天功能、营销文案生成功能、智能代码生成功能和智能问答功能。每个功能都可以在特定的实际场景下,发挥重要的作用,实现降本增效的效果。

一、前言

之前我们已经在一站式AI智能平台中实现了实时流式聊天功能,那为何这里我们还要实现通用聊天功能呢?实际上就是两种不同的实现方式,一站式AI智能平台集成两种不同的聊天方式,到时完成后,大家可以根据自己的喜好使用哪一种。AI智能平台本身不会限制大家的使用,这也是作为一站式AI智能平台的基本设计原则。

二、本节诉求

对一站式AI智能平台的通用聊天功能进行设计与实现,从全局角度掌握一站式AI智能平台的整体项目结构。重点掌握一站式AI智能平台的通用设计思路和设计方法,并能够将其灵活应用到自身实际项目中。

三、核心类设计

注意:本节只给大家展示一站式AI智能平台通用聊天功能的核心类实现关系,其他代码的实现细节,大家可以自行到本节对应的源码分支进行查看,这里不再赘述。

一站式AI智能平台通用聊天功能的核心类设计如图6-1所示。


本节的实现中,主要是在AiChatToolsService接口、AiChatToolsServiceImpl实现类和AiChatToolsController类中新增了commonAiChat()方法。这个commonAiChat()方法就是一站式AI智能平台智通用聊天功能的核心方法。

四、编码实现

本节只给大家展示一站式AI智能平台通用聊天功能的核心类编码实现,其他代码的实现细节,大家可以自行到本节对应的源码分支进行查看,这里不再赘述。

(1)定义通用聊天功能的方法

在AiChatToolsService接口中定义commonAiChat方法作为通用聊天功能的核心方法。

源码详见:io.binghe.ai.chat.tools.service.AiChatToolsService#commonAiChat。

/**
 * 通用对话聊天
 */
AiMessageResponse commonAiChat(AiMessageRequest request);

(2)实现通用聊天功能的方法

在AiChatToolsServiceImpl类中实现AiChatToolsService接口中定义的commonAiChat()方法,在commonAiChat()方法的具体实现中,会通过构建通用聊天功能的提示词,设置通用聊天功能的参数。通过调用chatModel的call方法来调用AI大模型,并接收AI大模型返回的结果数据,最终将AI大模型返回的结果数据封装成AiMessageResponse模型返回给调用方。

源码详见:io.binghe.ai.chat.tools.service.impl.AiChatToolsServiceImpl#commonAiChat。

@Override
public AiMessageResponse commonAiChat(AiMessageRequest request) {
	try{
		long startTime = System.currentTimeMillis();
		String promptStr = StringUtils.hasLength(request.getSystemPrompt()) ? request.getSystemPrompt() : Constants.PROMPT_COMMON_CHAT;

		// 设置提示词
		PromptTemplate promptTemplate = new PromptTemplate(promptStr.concat("\n\n用户: ").concat(Constants.CONTENT_PARAMS));
		Prompt prompt = promptTemplate.create(Map.of(Constants.CONTENT_KEY, request.getContent()));

		// 设置聊天参数
		DeepSeekChatOptions options = DeepSeekChatOptions.builder()
				.temperature(request.getTemperature() == null ? Constants.DEFAULT_TEMPERATURE : request.getTemperature())
				.maxTokens(request.getMaxTokens() == null ? Constants.DEFAULT_MAX_TOKENS : request.getMaxTokens())
				.build();

		// 调用大模型
		ChatResponse chatResponse = chatModel.call(new Prompt(prompt.getInstructions(), options));
		String content = chatResponse.getResult().getOutput().getText();

		long executeTime = System.currentTimeMillis() - startTime;
		log.info("聊天耗时: {}ms",  executeTime);

		AiMessageResponse aiMessageResponse = AiMessageResponse.success(content, Constants.MODEL_DEEPSEEK_CHAT);
		aiMessageResponse.setExecuteTimeMs(executeTime);
		return aiMessageResponse;
	}catch (Exception e){
		log.error("与AI大模型对话失败: ", e);
		return AiMessageResponse.error("与AI大模型对话失败: " + e.getMessage());
	}
}

(3)实现通用聊天功能代码的接口方法

在AiChatToolsController类中新增commonAiChat方法作为智能问答功能的HTTP接口的映射方法,对外接收AiMessageRequest参数,并响应AiMessageResponse结果数据。

源码详见:io.binghe.ai.chat.tools.controller.AiChatToolsController#commonAiChat。

查看完整文章

加入冰河技术知识星球,解锁完整技术文章、小册、视频与完整代码

写在最后

在冰河技术知识星球, 《AI智能代码审查平台》 已完结,同时,《AI全链路短剧生成平台》 、《企业级OpenClaw》 项目热更中,还有其他二十几个项目,像实战Claude Code、AI知识库系统、智流助手平台、智能成语挑战赛项目、多轮AI智能对话系统、一站式AI智能平台、AI智能客服系统、AI智能问答系统、实战AI大模型、手写高性能敏组件、手写线程池、手写高性能SQL引擎、手写高性能Polaris网关、手写高性能熔断组件、手写通用指标上报组件、手写高性能数据库路由组件、手写分布式IM即时通讯系统、手写Seckill分布式秒杀系统、手写高性能RPC、实战高并发设计模式、简易商城系统等等。

这些项目的需求、方案、架构、落地等均来自互联网真实业务场景,让你真正学到互联网大厂的业务与技术落地方案,并将其有效转化为自己的知识储备。

值得一提的是:冰河自研的Polaris高性能网关比某些开源网关项目性能更高,目前正在热更AI一体化项目,也正在实现MCP,全程带你分析原理和手撸代码。

你还在等啥?不少小伙伴经过星球硬核技术和项目的历练,早已成功跳槽加薪,实现薪资翻倍,而你,还在原地踏步,抱怨大环境不好。抛弃焦虑和抱怨,我们一起塌下心来沉淀硬核技术和项目,让自己的薪资更上一层楼。

🚀PS:目前已开通最大优惠:长按或扫码加入星球立减30,注意:随着项目和专栏的更新,星球也即将涨价!!


目前,领券加入星球就可以跟冰河一起学习《实战Claude Code》、《多轮AI智能对话系统》、《一站式AI智能平台》、《AI智能客服系统》、《AI智能问答系统》、《实战AI大模型》、《手写高性能Redis组件》、《手写高性能脱敏组件》、《手写线程池》、《手写高性能SQL引擎》、《手写高性能Polaris网关》、《手写高性能RPC项目》、《分布式Seckill秒杀系统》、《分布式IM即时通讯系统》《手写高性能通用熔断组件项目》、《手写高性能通用监控指标上报组件》、《手写高性能数据库路由组件》、《手写简易商城脚手架项目》、《Spring6核心技术与源码解析》和《实战高并发设计模式》,从零开始介绍原理、设计架构、手撸代码。

花很少的钱就能学这么多硬核技术、中间件项目和大厂秒杀系统、分布式IM即时通讯系统,AI大模型项目,比其他培训机构不知便宜多少倍,硬核多少倍,如果是我,我会买他个十年!

加入要趁早,后续还会随着项目和加入的人数涨价,而且只会涨,不会降,先加入的小伙伴就是赚到。

另外,还有一个限时福利,邀请一个小伙伴加入,冰河就会给一笔 分享有奖 ,有些小伙伴都邀请了50+人,早就回本了!

其他方式加入星球

  • 链接 :打开链接 http://m6z.cn/6aeFbs 加入星球。
  • 回复 :在公众号 冰河技术 回复 星球 领取优惠券加入星球。

特别提醒: 苹果用户进圈或续费,请加微信 hacker_binghe 扫二维码,或者去公众号 冰河技术 回复 星球 扫二维码加入星球。

好了,今天就到这儿吧,我是冰河,我们下期见~~

在 GitHub 上编辑此页
上次更新: 2026/4/29 04:08
Contributors: binghe001
Prev
第05节:智能问答功能的设计与实现
阅读全文
×

扫码或搜索:冰河技术
发送:290992
即可立即永久解锁本站全部文章

星球会员
跳转链接