Langchain+FastApi+Vue前后端Ai對話(超詳細)

一、引入

首先可以先看下作者的文章

  • FastApi相關文章:創建最簡單FastApi的項目
  • Vue相關文章:最簡單的aixos二次封裝
  • Langchain相關文章:如何使用LangSmith跟蹤deepseek模型

二、后端搭建

1 項目文件結構

  • routers:存放api接口
  • service:存放實際操作函數
  • init.py: 掛載接口
  • main:運行程序

2 創建聊天接口

3 創建chatService

一定要配置代理和模型密鑰

4 掛載接口

5 運行主函數

三、前端搭建

1 創建axios實例

2 創建請求

3 發送請求

4 界面布局

界面布局的源代碼

<template><div class="chat-container"><div class="timeline-container"><el-timeline><el-timeline-itemv-for="(activity, index) in activities":key="index":icon="activity.icon":type="activity.type":color="activity.color":size="activity.size":hollow="activity.hollow":timestamp="activity.timestamp">{{ activity.content }}</el-timeline-item></el-timeline></div><div id="container" class="input-container"><div id="chat" class="chat-input"><el-inputv-model="msg"input-style="width: calc(100% - 80px); height: 60px; border-radius: 8px;":rows="2"type="text"placeholder="請輸入消息"@keydown.enter="sendMsg();"/><el-button @click="sendMsg()" class="send-button">發送</el-button></div></div></div>    
</template>
<script setup>
import { MoreFilled } from '@element-plus/icons-vue'
import {ref, onMounted} from "vue";
import {getChat} from '@/api/chat'const activities = ref([{content: '請問有什么可以幫您的?',timestamp: new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString(),color: '#0bbd87',},
]);const msg = ref('');const sendMsg = () => {activities.value.push({content: `你:${msg.value}`,timestamp: new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString(),size: 'large',type: 'primary',icon: MoreFilled,},);activities.value.push({content: 'waiting...',timestamp: new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString(),color: '#0bbd87',},);getChat(msg.value).then(res => {activities.value.pop();activities.value.push({content: res.data,timestamp: new Date().toLocaleDateString() + " " + new Date().toLocaleTimeString(),color: '#0bbd87',},);});msg.value = '';
};
</script>
<style scoped>.chat-container {background-color: #A8C9D4;padding: 10px;border-radius: 8px;width: 600px;height: 500px;display: flex;flex-direction: column;}.timeline-container {height: 600px;width: 100%;overflow-y: auto;border: 1px solid #1e7ba2;border-radius: 8px;padding: 10px;}.input-container {margin-top: 10px;}.chat-input {display: flex;align-items: center;}.send-button {margin-left: 10px;height: 60px;border-radius: 8px;}
</style>

5 配置代理

四、展示效果

五、源代碼

源代碼地址:天才奇男子/學習筆記

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/66361.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/66361.shtml
英文地址,請注明出處:http://en.pswp.cn/web/66361.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何在不暴露MinIO地址的情況下,用Spring Boot與KKFileView實現文件預覽

在現代Web應用中&#xff0c;文件預覽是一項常見且重要的功能。它允許用戶在不上傳或下載文件的情況下&#xff0c;直接在瀏覽器中查看文件內容。然而&#xff0c;直接將文件存儲服務&#xff08;如MinIO&#xff09;暴露給前端可能會帶來安全風險。本文將介紹如何在不暴露MinI…

簡歷_使用優化的Redis自增ID策略生成分布式環境下全局唯一ID,用于用戶上傳數據的命名以及多種ID的生成

系列博客目錄 文章目錄 系列博客目錄WhyRedis自增ID策略 Why 我們需要設置全局唯一ID。原因&#xff1a;當用戶搶購時&#xff0c;就會生成訂單并保存到tb_voucher_order這張表中&#xff0c;而訂單表如果使用數據庫自增ID就存在一些問題。 問題&#xff1a;id的規律性太明顯、…

Jira中bug的流轉流程

Jira中bug的狀態 1. 處理Bug的流程2. bug狀態流轉詳述bug的狀態通常包括 1. 處理Bug的流程 2. bug狀態流轉詳述 bug的狀態通常包括 未解決 1. 測試人員創建一個bug&#xff0c;填寫bug的詳細信息&#xff0c;如概要、bug級別、復現步驟、現狀、預期結果等 2. 定位bug&#x…

Linux的幾個基本指令

文章目錄 一、幾個基本指令1、ls 指令注意&#xff01; 2、pwd命令3、touch 指令4、mkdir 指令注意&#xff01;注意&#xff01; 5、cd 指令注意&#xff01; 6、cp 指令 今天我們學習Linux下的幾個基本指令&#xff0c;本篇是在Xshell環境下執行的。 一、幾個基本指令 1、…

軟件工程師歐以寧:引領無人機導航與物聯網安全的技術革新

在科技日新月異的今天,軟件工程師歐以寧憑借卓越的技術能力和前瞻性的創新思維,成為了無人機自主導航和物聯網安全領域的佼佼者。作為一名深耕技術前沿的專家,歐以寧不僅推動了無人機導航技術的突破性進展,還為智能家居和物聯網的安全架構提供了全新的解決方案。她的研究成果,以…

數據庫基礎練習1(創建表,設置外鍵,檢查,不為空,主鍵等約束)安裝mysql詳細步驟

安裝MySQL詳細步驟 1. 下載 MySQL 安裝程序 訪問 MySQL 官方網站&#xff1a;MySQL Downloads。在下載頁面&#xff0c;選擇 "MySQL Community (GPL) Downloads"。在 "MySQL Community Server" 部分&#xff0c;根據你的操作系統&#xff08;Windows&…

laravel中請求失敗重試的擴展--Guzzle

背景 開發過程中&#xff0c;跟外部接口對接時&#xff0c;很常見的要考慮到失敗重新的情況&#xff0c;這里記錄一下我用的失敗重試的情況&#xff0c; 重試方法 1、使用 Laravel 的 HTTP 客戶端和異常處理 結合異常處理和重試邏輯 use Illuminate\Support\Facades\Http;…

ThinkPHP 8的一對多關聯

【圖書介紹】《ThinkPHP 8高效構建Web應用》-CSDN博客 《2025新書 ThinkPHP 8高效構建Web應用 編程與應用開發叢書 夏磊 清華大學出版社教材書籍 9787302678236 ThinkPHP 8高效構建Web應用》【摘要 書評 試讀】- 京東圖書 使用VS Code開發ThinkPHP項目-CSDN博客 編程與應用開…

工業網口相機:如何通過調整網口參數設置,優化圖像傳輸和網絡性能,達到最大幀率

項目場景 工業相機是常用與工業視覺領域的常用專業視覺核心部件&#xff0c;擁有多種屬性&#xff0c;是機器視覺系統中的核心部件&#xff0c;具有不可替代的重要功能。 工業相機已經被廣泛應用于工業生產線在線檢測、智能交通,機器視覺,科研,軍事科學,航天航空等眾多領域 …

java使用poi-tl自定義word模板導出

文章目錄 概要整體架構流程創建word模板核心代碼導出結果 概要 在軟件開發領域&#xff0c;自定義Word模板的使用是導出格式化數據的一種常見做法。poi-tl&#xff08;Apache POI Template Language&#xff09;作為一款基于廣受認可的Apache POI庫的Word模板引擎&#xff0c;…

IDEA2023版中TODO的使用

介紹&#xff1a;TODO其實本質上還是注釋&#xff0c;只不過加上了TODO這幾個字符&#xff0c;可以讓使用者快速找到。 注意&#xff1a;在類、接口等文件中&#xff0c;注釋是使用// 即&#xff1a;// TODO 注釋內容 在配置文件中&#xff0c;注釋是使用# 即&#xff1a;# TO…

項目練習:若依管理系統字典功能-Vue前端部分

文章目錄 一、情景說明二、若依Vue相關代碼及配置1、utils代碼2、components組件3、api接口代碼4、Vuex配置5、main.js配置 三、使用方法1、html部分2、js部分 一、情景說明 我們在做web系統的時候&#xff0c;肯定會遇到一些常量選擇場景。 比如&#xff0c;性別&#xff1a;…

LabVIEW開發X光圖像的邊緣檢測

在醫療影像處理中&#xff0c;X光圖像的分析對于骨折、腫瘤等病變的檢測非常重要。X光圖像中包含許多關鍵信息&#xff0c;然而&#xff0c;由于圖像噪聲的干擾&#xff0c;直接從圖像中提取有用的特征&#xff08;如骨折的邊緣&#xff09;變得非常困難。邊緣檢測作為圖像處理…

【CC2640R2F】香瓜CC2640R2F之SPI讀寫W25Q80

本文最后修改時間&#xff1a;2022年01月08日 10:45 一、本節簡介 本節以simple_peripheral工程為例&#xff0c;介紹如何使用SPI讀寫W25Q80&#xff08;外部flash&#xff09;。 二、實驗平臺 1&#xff09;CC2640R2F平臺 ①協議棧版本&#xff1a;CC2640R2 SDK v1.40.00.4…

光譜相機如何還原色彩

多光譜通道采集 光譜相機設有多個不同波段的光譜通道&#xff0c;可精確記錄每個波長的光強信息。如 8 到 16 個甚至更多的光譜通道&#xff0c;每個通道負責特定波長范圍的光信息記錄。這使得相機能分辨出不同光譜組合產生的相同顏色感知&#xff0c;而傳統相機的傳感器通常只…

C# 獲取PDF文檔中的字體信息(字體名、大小、顏色、樣式等

在設計和出版行業中&#xff0c;字體的選擇和使用對最終作品的質量有著重要影響。然而&#xff0c;有時我們可能會遇到包含未知字體的PDF文件&#xff0c;這使得我們無法準確地復制或修改文檔。獲取PDF中的字體信息可以解決這個問題&#xff0c;讓我們能夠更好地處理這些文件。…

C++ 的 CTAD 與推斷指示(Deduction Guides)

1 類模板參數推導&#xff08;CTAD&#xff09; 1.1 曲線救國 ? CTAD 的全稱是類模板參數推導&#xff08;Class Template Argument Deduction&#xff09;&#xff0c;它允許在實例化類模板時&#xff0c;根據構造函數的參數類型自動推導模板參數&#xff0c;從而避免顯式指…

Shell正則表達式與文本處理三劍客(grep、sed、awk)

一、正則表達式 Shell正則表達式分為兩種&#xff1a; 基礎正則表達式&#xff1a;BRE&#xff08;basic regular express&#xff09; 擴展正則表達式&#xff1a;ERE&#xff08;extend regular express&#xff09;&#xff0c;擴展的表達式有、?、|和() 1.1 基本正則表…

掌握 React 高階組件與高階函數:構建可復用組件的新境界

一、引言 在 React 開發中&#xff0c;代碼復用性和邏輯分離是提高開發效率和維護性的重要手段。高階組件&#xff08;Higher-Order Component, HOC&#xff09;和高階函數&#xff08;Higher-Order Function, HOF&#xff09;是實現這一目標的兩種強大工具。本文將詳細介紹這…

arcgis提取不規則柵格數據的矢量邊界

效果 1、準備數據 柵格數據:dem或者dsm 2、柵格重分類 分成兩類即可 3、新建線面圖層 在目錄下選擇預先準備好的文件夾,點擊右鍵,選擇“新建”→“Shapefile”,新建一個Shapefile文件。 在彈出的“新建Shapefile”對話框內“名稱”命名為“折線”,“要素類型”選…