[Go] 实现websocket服务端

直接使用官方子包可以实现websocket协议,

golang.org/x/net/websocket
如果在这个目录没有这个包就去github下载net库,放进这个目录$GOPATH/src/golang.org/x/net就行了
服务端代码:
复制代码
package main

import (
    "time"
    "log"
    "net/http"
    "golang.org/x/net/websocket"
)
func main(){
    http.HandleFunc("/",index)
    http.Handle("/websocket",websocket.Handler(instantMessage))
    log.Println("start server")
    err:=http.ListenAndServe(":1234",nil)
    log.Println(err)
}
func index(res http.ResponseWriter,req *http.Request){
    res.Write([]byte("hello world"))
}
func instantMessage(w *websocket.Conn)  {
    var error error
    for {
        var reply string
        if  error= websocket.Message.Receive(w,&reply);error!=nil{
            log.Println("接受消息失败",error)
            break
        }
        log.Println("客户端:",reply)
        
        msg:="服务端:"+reply+time.Now().String()
        log.Println(msg)
        if error = websocket.Message.Send(w, msg); error != nil {
            log.Println("发送消息失败")
            break
        }
    }
}
复制代码

客户端代码:

复制代码
<html>
<head>
    <title>好好学习</title>
</head>
<body>
<script type="text/javascript">
    var sock = null;
    // var wsuri = "wss://127.0.0.1:8080"; //本地的地址 是可以改变的哦
     var wsuri = "ws://localhost:1234/websocket"; //本地的地址 是可以改变的哦


    window.onload = function() {
        //可以看到客户端JS,很容易的就通过WebSocket函数建立了一个与服务器的连接sock,当握手成功后,会触发WebScoket对象的onopen事件,告诉客户端连接已经成功建立。客户端一共绑定了四个事件。
        console.log("开始了 onload");
        sock = new WebSocket(wsuri);
        //建立连接后触发
        sock.onopen = function() {
            console.log(" 建立连接后触发 connected to " + wsuri);
        }
        // 关闭连接时候触发
        sock.onclose = function(e) {
            console.log("关闭连接时候触发 connection closed (" + e.code + ")");
        }
        // 收到消息后触发
        sock.onmessage = function(e) {
            console.log("收到消息后触发 message received: " + e.data);
            document.getElementById('receive').innerHTML=e.data;
        }
        //发生错误的时候触发
        sock.onerror=function (e) {
            console.log("发生错误时候触发"+wsuri)
        }
    };
     //如果sock被关闭掉了 这里 也会报错的啊
    function send() {
        var msg = document.getElementById('message').value;
        sock.send(msg);
    };
</script>
<h1>客户端</h1>
<form>
    <p>发送: </p>
    <textarea id="message" >我是陶士涵</textarea>
    <p>接收: </p>
    <textarea id="receive" ></textarea>
</form>
<button onclick="send();">给服务器发送消息</button>
</body>
</html>
复制代码

 

 

 

posted @   唯一客服系统开发笔记  阅读(2458)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示
1
chat with us