golang實(shí)現(xiàn)一個(gè)簡(jiǎn)單的websocket聊天室功能
基本原理:
1.引入了 golang.org/x/net/websocket 包。
2.監(jiān)聽(tīng)端口。
3.客戶(hù)端連接時(shí),發(fā)送結(jié)構(gòu)體: {"type":"login","uid":"我是用戶(hù)名","msg":"登陸成功"}' .服務(wù)端根據(jù)login信息,維護(hù)一個(gè)map,用來(lái)存放不同用戶(hù)的連接體。
4.有用戶(hù)發(fā)言時(shí),將msg內(nèi)容輪詢(xún)發(fā)給給一個(gè)用戶(hù)。
5.客戶(hù)端使用js websocket功能,當(dāng)作客戶(hù)端,開(kāi)始聊天。
不足之處:只是根據(jù)客戶(hù)端傳的uid來(lái)區(qū)分用戶(hù),沒(méi)有進(jìn)行身份校驗(yàn),不過(guò)對(duì)一個(gè)demo來(lái)說(shuō),也沒(méi)必要。
server代碼:
package main
import (
"encoding/json"
"fmt"
"golang.org/x/net/websocket"
"log"
"net/http"
)
//ProxyConfig 配置
type MsgConfig struct {
Type string `json:"type,omitempty"`
Uid string `json:"uid,omitempty"`
Msg string `json:"msg,omitempty"`
}
var connMap = make(map[string]*websocket.Conn)
func Echo(ws *websocket.Conn) {
var err error
for {
var reply string
if err = websocket.Message.Receive(ws, &reply); err != nil {
fmt.Println("Can't receive")
break
}
replyMsg := MsgConfig{}
json.Unmarshal([]byte(reply), &replyMsg)
if replyMsg.Type == "login" && replyMsg.Uid != "" {
connMap[replyMsg.Uid] = ws
fmt.Println(connMap)
}
for k, v := range connMap {
go sendMessage(replyMsg, v, k)
}
}
}
func sendMessage(replyMsg MsgConfig, conn *websocket.Conn, connUid string) {
msg := replyMsg.Uid + "說(shuō):" + replyMsg.Msg
if connUid == replyMsg.Uid {
fmt.Println(msg)
if replyMsg.Type == "login" {
msg = "登陸成功"
} else {
msg = "你說(shuō):" + replyMsg.Msg
}
}
if err := websocket.Message.Send(conn, msg); err != nil {
fmt.Println("Can't send")
}
}
func main() {
http.Handle("/", websocket.Handler(Echo))
if err := http.ListenAndServe(":1234", nil); err != nil {
log.Fatal("ListenAndServe:", err)
}
}
客戶(hù)端聊天:
可以在瀏覽器的控制臺(tái)里面輸入以下代碼,進(jìn)行聊天:
//ip:port設(shè)置成自己的
ws = new WebSocket("ws://127.0.0.1:1234");
ws.onopen = function (ev) {
ws.send('{"type":"login","uid":"我是用戶(hù)名","msg":"我登陸了"}');
};
ws.onmessage = function (ev) {
if (ev.data){
console.log(ev.data)
}
};
//下面這句可以多次發(fā)送,當(dāng)作是聊天。
ws.send('{"type":"msg","uid":"我是用戶(hù)名","msg":"你好啊"}');
客戶(hù)端效果圖:

服務(wù)器效果圖:

摘自https://www.yuanshuli.com/post-60.html
到此這篇關(guān)于golang實(shí)現(xiàn)一個(gè)簡(jiǎn)單的websocket聊天室的文章就介紹到這了,更多相關(guān)golang websocket聊天室內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用golang和shell計(jì)算一個(gè)字符串的md5值
這篇文章主要介紹了如何利用golang和shell計(jì)算一個(gè)字符串的md5值,我們先用shell來(lái)計(jì)算一下,再去判斷golang計(jì)算的md5值是否正確,文中有詳細(xì)的圖文介紹,需要的朋友可以參考下2024-03-03
Go語(yǔ)言實(shí)現(xiàn)配置熱加載的方法分享
web項(xiàng)目,經(jīng)常需要熱啟動(dòng)各種各樣的配置信息,一旦這些服務(wù)發(fā)生變更,我們需要重新啟動(dòng)web server,以使配置生效,實(shí)現(xiàn)配置熱加載,本文為大家整理了幾個(gè)方法實(shí)現(xiàn)這個(gè)需求,需要的可以參考下2023-05-05
golang使用map支持高并發(fā)的方法(1000萬(wàn)次操作14ms)
這篇文章主要介紹了golang使用map支持高并發(fā)的方法(1000萬(wàn)次操作14ms),本文給大家詳細(xì)講解,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11
深入了解GoLang中的工廠(chǎng)設(shè)計(jì)模式
這篇文章主要介紹了深入了解GoLang中的工廠(chǎng)設(shè)計(jì)模式,工廠(chǎng)模式是一種常用的設(shè)計(jì)模式,它屬于創(chuàng)建型模式,它的主要目的是封裝對(duì)象的創(chuàng)建過(guò)程,將對(duì)象的創(chuàng)建過(guò)程與對(duì)象的使用過(guò)程分離,從而提高代碼的可維護(hù)性和可擴(kuò)展性,需要詳細(xì)了解可以參考下文2023-05-05
Go語(yǔ)言實(shí)現(xiàn)LRU算法的核心思想和實(shí)現(xiàn)過(guò)程
這篇文章主要介紹了Go語(yǔ)言實(shí)現(xiàn)LRU算法的核心思想和實(shí)現(xiàn)過(guò)程,LRU算法是一種常用的緩存淘汰策略,它的核心思想是如果一個(gè)數(shù)據(jù)在最近一段時(shí)間內(nèi)沒(méi)有被訪(fǎng)問(wèn)到,那么在將來(lái)它被訪(fǎng)問(wèn)的可能性也很小,因此可以將其淘汰,感興趣想要詳細(xì)了解可以參考下文2023-05-05
golang開(kāi)發(fā)安裝go-torch火焰圖操作步驟
這篇文章主要為大家介紹了golang開(kāi)發(fā)安裝go-torch火焰圖操作步驟2021-11-11

