使用 JavaScript 和 Gemini AI 創建聊天機器人:創建後端
保存!哦
繼續使用 Javascript 和 Gemini AI 創建我們的聊天機器人,我們將添加專案的「後端」。上次我們使用 HTML、CSS 和 Javascript 創建前端,我們保證使用者介面將反映使用者和聊天機器人之間的對話。
現在我們需要建立一個伺服器,使用express.js設定路由來與Gemini API進行通訊。我們走吧!
安裝專案依賴項
好吧,我們需要express.js、Google Gemini SDK,為了保護我們的API金鑰,我將安裝dotenv來使用環境變數。
npm install @google/generative-ai express dotenv
現在我們準備好採用最佳實務建立伺服器,例如使用本地環境變數來保護私有資料。
為此,我們將在專案根資料夾中建立一個名為 server.js 的檔案。在此文件中,我們將首先導入依賴項並配置必要的資源。
const express = require("express"); require("dotenv").config(); const { GoogleGenerativeAI } = require("@google/generative-ai"); const app = express(); const port = 3000; const genAI = new GoogleGenerativeAI(process.env.GOOGLE_GEMINI_API_KEY); app.use(express.static("public")); app.use(express.json());
此程式碼將 Express 配置為從「public」資料夾提供靜態文件,並接受帶有 JSON 負載的請求。這就是為什麼我們將index.html、styles.css 和script.js 檔案放在這個資料夾中。我們還將應用程式配置為在連接埠 3000 上運行。
我們使用 @google/generative-ai 函式庫來整合 Gemini API,並使用儲存在名為 GOOGLE_GEMINI_API_KEY 的環境變數中的金鑰對其進行驗證。
但是我們要從哪裡取得這個 API Key 呢?這就是我們現在要找出的。
雙子座 API 金鑰
取得密鑰
要取得 Gemini API 金鑰,我建議您登入「@gmail.com」帳戶。之後,訪問此鏈接,您將看到如下屏幕:
按一下「建立 API 金鑰」按鈕,指定您將在其中使用此金鑰的項目,然後就完成了。您的密鑰將顯示在下方,您可以查看它,甚至可以複製它以進行下一步。
保護您的 API 金鑰
現在在您的專案中,在專案的根資料夾中建立一個名為 .env.local 或僅 .env 的檔案。在此文件中輸入您的 API 金鑰,如下所示:
GOOGLE_GEMINI_API_KEY="sua-chave-vai-aqui"
現在儲存您的檔案即可。如果您正確執行了上一步,您的 API 金鑰將會起作用。
PS:請注意您的 API 金鑰中顯示的計畫。 Gemini 提供免費計劃,您的鑰匙可以返還有限數量的代幣。如果您想要更多的代幣,請考慮訂閱付費方案。我們將使用免費計劃,雖然有限,但允許我們與聊天機器人交換一些訊息。
建立 /chat 路由
現在配置了依賴項並掌握了 API 金鑰,讓我們打開人工智慧的可能性之門。
在 server.js 檔案中,我們將建立 /chat 路由:
npm install @google/generative-ai express dotenv
我們的路由是 POST 類型,因為您將在正文中收到一條訊息,正是來自將與聊天互動的用戶的訊息。因此,對於此訊息,我們使用了一些防禦性程式設計(小心一點不會傷害任何人,哈哈)並檢查我們是否沒有收到訊息。如果不這樣做,則會傳回錯誤作為回應,並拋出一條訊息。
如果我們有訊息,那麼我們會將其作為我們選擇的模型的提示發送,如下所示:
const express = require("express"); require("dotenv").config(); const { GoogleGenerativeAI } = require("@google/generative-ai"); const app = express(); const port = 3000; const genAI = new GoogleGenerativeAI(process.env.GOOGLE_GEMINI_API_KEY); app.use(express.static("public")); app.use(express.json());
由於此通訊是一個非同步過程,因此我們將使用 try/catch 來處理回應。首先,我定義將使用的 Gemini 模型(您可以在此連結中查看模型清單)。在這種情況下,我選擇了gemini-1.5-flash。
第二步是開始聊天。因此,透過 model.startChat() 我可以開始與 Gemini 通信,配置我想要在響應中的最大令牌數(在本例中每個響應 100 個令牌)。
現在,我們在使用 chat.sendMessage(message) 將訊息傳送到模型後等待此回應。當我們收到回應時,我們會將其傳回給發出請求的人,並將模型傳回的文字格式轉換為 JSON。
最後但並非最不重要的一點是,如果我們遇到錯誤,我們可以在catch 中使用它在控制台中拋出此錯誤,並返回狀態500,使使用此“迷你api”的客戶端的生活更輕鬆。美麗?
現在我們只需要使用下面的程式碼片段來指示我們的「mini api」將在哪裡運行:
GOOGLE_GEMINI_API_KEY="sua-chave-vai-aqui"
我們的 api 將在我們一開始指定的連接埠上運行。完整的server.js程式碼如下圖所示:
app.post("/chat", async (req, res) => { const { message } = req.body; if (!message) { return res.status(400).json({ error: "Mensagem não pode estar vazia." }); } //... });
測試聊天機器人
現在最期待的時刻到了,測試我們的聊天機器人。為此,我們打開終端機並輸入以下命令:
try { const model = genAI.getGenerativeModel({ model: "gemini-1.5-flash", }); const chat = model.startChat({ history: [], generationConfig: { maxOutputTokens: 100 }, }); const result = await chat.sendMessage(message); res.json({ response: result.response.text() }); } catch (error) { console.error(error); res.status(500).json({ error: "Erro ao processar mensagem." }); }
運行此命令後,您應該在終端機中收到以下訊息:
app.listen(port, () => { console.log(`Servidor rodando em http://localhost:${port}`); });
現在,透過造訪 URL http://localhost:3000 並在輸入中寫入訊息並按下傳送按鈕,AI 會回覆您的訊息並將其顯示在螢幕上。
非常酷,對吧?
結論
至此,我們使用 JavaScript 和 Google Gemini API 完成了聊天機器人的創建。我們了解如何從頭開始建立前端、應用程式樣式、操作 DOM。我們使用express.js創建了一個伺服器,使用了Gemini API,配置了一條POST路由來與應用程式用戶端通信,並能夠透過我們自己開發的介面與AI對話。
但這並不是您能做的全部。我們可以為不同的任務客製化和配置這個聊天機器人,從語言助理,到回答你的數學或程式設計問題的虛擬老師,這將取決於你的創造力。
將人工智慧轉變為個人化助手需要訓練模型,更多的是關於你希望它響應和表現的方式,而不是程式碼本身。
我們將在以後的文章中探討其中的一些內容。
到時候見!
以上是使用 JavaScript 和 Gemini AI 創建聊天機器人:創建後端的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務
