使用 data-star 與機器人即時聊天
Hello everyone,
in part 1 i made simple server side clock https://dev.to/blinkinglight/golang-data-star-1o53/
and now decided to write more complex things using https://nats.io and https://data-star.dev -
Chat bot which returns what you wrote to it:
some golang code:
package handlers import ( "encoding/json" "fmt" "log" "net/http" "github.com/blinkinglight/chat-data-star/web/views/chatview" "github.com/delaneyj/datastar" "github.com/delaneyj/toolbelt" "github.com/delaneyj/toolbelt/embeddednats" "github.com/go-chi/chi/v5" "github.com/gorilla/sessions" "github.com/nats-io/nats.go" ) func SetupChat(router chi.Router, session sessions.Store, ns *embeddednats.Server) error { type Message struct { Message string `json:"message"` Sender string `json:"sender"` } nc, err := ns.Client() if err != nil { return err } nc.Subscribe("chat.>", func(msg *nats.Msg) { var message = Message{} err := json.Unmarshal(msg.Data, &message) if err != nil { log.Printf("%v", err) return } if message.Sender != "bot" { // do something with user message and send back response nc.Publish("chat."+message.Sender, []byte(`{"message":"hello, i am bot. You send me: `+message.Message+`", "sender":"bot"}`)) } }) _ = nc chatIndex := func(w http.ResponseWriter, r *http.Request) { _, err := upsertSessionID(session, r, w) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } chatview.Index().Render(r.Context(), w) } chatMessage := func(w http.ResponseWriter, r *http.Request) { id, err := upsertSessionID(session, r, w) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } var state = Message{} err = datastar.BodyUnmarshal(r, &state) if err != nil { http.Error(w, err.Error(), http.StatusBadRequest) return } state.Sender = id b, err := json.Marshal(state) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } nc.Publish("chat."+id, b) sse := datastar.NewSSE(w, r) _ = sse } chatMessages := func(w http.ResponseWriter, r *http.Request) { id, err := upsertSessionID(session, r, w) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } var ch = make(chan *nats.Msg) sub, err := nc.Subscribe("chat."+id, func(msg *nats.Msg) { ch <- msg }) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } defer close(ch) defer sub.Unsubscribe() sse := datastar.NewSSE(w, r) for { select { case <-r.Context().Done(): return case msg := <-ch: var message = Message{} err := json.Unmarshal(msg.Data, &message) if err != nil { datastar.Error(sse, err) return } if message.Sender == "bot" { datastar.RenderFragmentTempl(sse, chatview.Bot(message.Message), datastar.WithMergeAppend(), datastar.WithQuerySelector("#chatbox")) } else { datastar.RenderFragmentTempl(sse, chatview.Me(message.Message), datastar.WithMergeAppend(), datastar.WithQuerySelector("#chatbox")) } } } } router.Get("/chat", chatIndex) router.Post("/chat", chatMessage) router.Get("/messages", chatMessages) return nil } func upsertSessionID(store sessions.Store, r *http.Request, w http.ResponseWriter) (string, error) { sess, err := store.Get(r, "chatters") if err != nil { return "", fmt.Errorf("failed to get session: %w", err) } id, ok := sess.Values["id"].(string) if !ok { id = toolbelt.NextEncodedID() sess.Values["id"] = id if err := sess.Save(r, w); err != nil { return "", fmt.Errorf("failed to save session: %w", err) } } return id, nil }
and template
package chatview import "github.com/blinkinglight/chat-data-star/web/views/layoutview" templ Index() { @layoutview.Main() { <!-- component --> <div class="fixed bottom-0 right-0 mb-4 mr-4"> <button id="open-chat" class="bg-blue-500 text-white py-2 px-4 rounded-md hover:bg-blue-600 transition duration-300 flex items-center"> <svg xmlns="http://www.w3.org/2000/svg" class="w-6 h-6 mr-2" fill="none" viewBox="0 0 24 24" stroke="currentColor"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 6v6m0 0v6m0-6h6m-6 0H6"></path> </svg> Chat with Admin Bot </button> </div> <div id="chat-container" class="hidden fixed bottom-16 right-4 w-96"> <div class="bg-white shadow-md rounded-lg max-w-lg w-full"> <div class="p-4 border-b bg-blue-500 text-white rounded-t-lg flex justify-between items-center"> <p class="text-lg font-semibold">Admin Bot</p> <button id="close-chat" class="text-gray-300 hover:text-gray-400 focus:outline-none focus:text-gray-400"> <svg xmlns="http://www.w3.org/2000/svg" class="w-6 h-6" fill="none" viewBox="0 0 24 24" stroke="currentColor"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"></path> </svg> </button> </div> <div id="chatbox" class="p-4 h-80 overflow-y-auto" data-on-load="$$get('/messages')" data-store="{ message: '' }"> <!-- Chat messages will be displayed here --> </div> <div class="p-4 border-t flex"> <input data-model="message" id="user-input" type="text" placeholder="Type a message" class="w-full px-3 py-2 border rounded-l-md focus:outline-none focus:ring-2 focus:ring-blue-500"/> <button data-on-keydown.window.key_enter="$$post('/chat'); $message=''" data-on-click="$$post('/chat'); $message=''" id="send-button" class="bg-blue-500 text-white px-4 py-2 rounded-r-md hover:bg-blue-600 transition duration-300">Send</button> </div> </div> </div> <script> const chatbox = document.getElementById("chatbox"); const chatContainer = document.getElementById("chat-container"); const userInput = document.getElementById("user-input"); const sendButton = document.getElementById("send-button"); const openChatButton = document.getElementById("open-chat"); const closeChatButton = document.getElementById("close-chat"); let isChatboxOpen = true; // Set the initial state to open function toggleChatbox() { chatContainer.classList.toggle("hidden"); isChatboxOpen = !isChatboxOpen; // Toggle the state } openChatButton.addEventListener("click", toggleChatbox); closeChatButton.addEventListener("click", toggleChatbox); toggleChatbox(); </script> } } templ Me(message string) { <div class="mb-2 text-right"> <p class="bg-blue-500 text-white rounded-lg py-2 px-4 inline-block">{ message }</p> </div> } templ Bot(message string) { <div class="mb-2"> <p class="bg-gray-200 text-gray-700 rounded-lg py-2 px-4 inline-block">{ message }</p> </div> }
you can find working example at https://github.com/blinkinglight/chat-data-star
以上是使用 data-star 與機器人即時聊天的詳細內容。更多資訊請關注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)

Go語言在構建高效且可擴展的系統中表現出色,其優勢包括:1.高性能:編譯成機器碼,運行速度快;2.並發編程:通過goroutines和channels簡化多任務處理;3.簡潔性:語法簡潔,降低學習和維護成本;4.跨平台:支持跨平台編譯,方便部署。

Golang在並發性上優於C ,而C 在原始速度上優於Golang。 1)Golang通過goroutine和channel實現高效並發,適合處理大量並發任務。 2)C 通過編譯器優化和標準庫,提供接近硬件的高性能,適合需要極致優化的應用。

Golang和C 在性能競賽中的表現各有優勢:1)Golang適合高並發和快速開發,2)C 提供更高性能和細粒度控制。選擇應基於項目需求和團隊技術棧。

Golang在性能和可擴展性方面優於Python。 1)Golang的編譯型特性和高效並發模型使其在高並發場景下表現出色。 2)Python作為解釋型語言,執行速度較慢,但通過工具如Cython可優化性能。

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。Golang以其并发模型和高效性能著称,Python则以简洁语法和丰富库生态系统著称。

C 更適合需要直接控制硬件資源和高性能優化的場景,而Golang更適合需要快速開發和高並發處理的場景。 1.C 的優勢在於其接近硬件的特性和高度的優化能力,適合遊戲開發等高性能需求。 2.Golang的優勢在於其簡潔的語法和天然的並發支持,適合高並發服務開發。

goimpactsdevelopmentpositationality throughspeed,效率和模擬性。 1)速度:gocompilesquicklyandrunseff,IdealforlargeProjects.2)效率:效率:ITScomprehenSevestAndardArdardArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增強的Depleflovelmentimency.3)簡單性。

Golang和C 在性能上的差異主要體現在內存管理、編譯優化和運行時效率等方面。 1)Golang的垃圾回收機制方便但可能影響性能,2)C 的手動內存管理和編譯器優化在遞歸計算中表現更為高效。
