Go-一个使用websocket的例子<github.com/gorilla/websocket>

一、服务端代码

package main

import (
	"encoding/json"
	"fmt"
	"net"
	"net/http"
	"time"
	"github.com/gorilla/websocket"
)

type msgJson struct {
	M_str string
}

func main() {
	//创建监听器
	listener,err := net.Listen("tcp", "127.0.0.1:18802")
	
	//控制连接我的客户端数量
	var num = 0
	
	//打印错误
	fmt.Println(err)
	
	
	mux := http.NewServeMux()
	var upgrader  = websocket.Upgrader{
		CheckOrigin:func(r *http.Request) bool {
			return true
		},
	} 

	mux.HandleFunc("/",func(w http.ResponseWriter,r *http.Request) {
		//升级成功后将获取到WebSocket.Conn 利用这个Conn可进行消息收发
		c,err :=  upgrader.Upgrade(w,r,nil)
		if err != nil {
			fmt.Println("upgrade error")
			return
		}


		num++

		//将msg转化成字节数组
		msg := msgJson{M_str: "xxxxx"}
		msgbyte,err := json.Marshal(msg)

		//var kkk msgJson
		//json.Unmarshal(msgbyte,&kkk)

		if err == nil {
			//发送
			c.WriteMessage(websocket.BinaryMessage,msgbyte)
		}
	})


	sv := http.Server{Addr: "127.0.0.1:18802",Handler: mux}

	go func() {
		err := sv.Serve(listener)
		fmt.Println("Http.serve error:",err)
	}()
	
	//阻塞主线程
	for {
		if num > 100 {
			time.Sleep(1000)
			break
		}
	}
}

二、客户端代码

提供了两种解决方案,一种是html,通过js与我们服务器进行交互,另一种是通过go编写的客户端与我们服务器交互

将下列代码保存为example.html文件

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<p>请将此文件拖拽到Chrome中打开,并按F12打开调试窗口,Console中查看结果</p>
<script type="text/javascript">

    // js二进制操作可参考 https://my.oschina.net/appnet/blog/1647923
    window.onload = function () {

        console.log("hello")

        let ws = new WebSocket("ws://127.0.0.1:18802");
       ws.binaryType = "arraybuffer";

        ws.onopen = function(evt) {
            console.log("Connection open ...");
        };

        ws.onmessage = function(evt) {
               // let dv = new DataView(evt.data);
                let decoder = new TextDecoder('utf8')
                let jsonBody = decoder.decode(evt.data)
                let jsonMsg = JSON.parse(jsonBody)
                console.log( "Received Message: " , jsonMsg);
                console.log('Retrieved data from server: ' + evt.data.length+', '+evt.data);
        };

        ws.onclose = function(evt) {
            console.log("Connection closed.");
        };
    }

</script>
</body>
</html>

将下列代码保存为client.go文件

package main

import (
	"encoding/json"
	"fmt"
	"net/http"
	"time"

	"github.com/gorilla/websocket"
)

type msgJson struct {
	M_str string
}

func main() {
	//
	//链接上服务端,并接收来自服务端的信息
	dialer := websocket.Dialer{}
	dialer.Proxy = http.ProxyFromEnvironment
	dialer.HandshakeTimeout = 45 * time.Second
	
	conn, _, err := dialer.Dial("ws://127.0.0.1:18802", nil)

	if err != nil {
		//
		fmt.Println("connect error")
	}else {
		fmt.Println("connect suc")
	}


	//接收来自服务器的消息并打印
     _, msgbyte, err := conn.ReadMessage()

	 fmt.Println(err)
	 var  msgobj msgJson
	 json.Unmarshal(msgbyte,&msgobj)

	 fmt.Println("msgObj:",msgobj)

	conn.Close()
	
}

三、效果展示

html的客户端

go的客户端

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
goroutine 9 [IO wait]: internal/poll.runtime_pollWait(0x3348a488, 0x72) D:/Program Files (x86)/Go/src/runtime/netpoll.go:305 +0x52 internal/poll.(*pollDesc).wait(0x1337e3b4, 0x72, 0x0) D:/Program Files (x86)/Go/src/internal/poll/fd_poll_runtime.go:84 +0x37 internal/poll.execIO(0x1337e2d4, 0xcf65e0) D:/Program Files (x86)/Go/src/internal/poll/fd_windows.go:175 +0xfc internal/poll.(*FD).Read(0x1337e2c0, {0x13cda000, 0x1000, 0x1000}) D:/Program Files (x86)/Go/src/internal/poll/fd_windows.go:441 +0x13b net.(*netFD).Read(0x1337e2c0, {0x13cda000, 0x1000, 0x1000}) D:/Program Files (x86)/Go/src/net/fd_posix.go:55 +0x3f net.(*conn).Read(0x13240078, {0x13cda000, 0x1000, 0x1000}) D:/Program Files (x86)/Go/src/net/net.go:183 +0x4f bufio.(*Reader).fill(0x13091020) D:/Program Files (x86)/Go/src/bufio/bufio.go:106 +0xe9 bufio.(*Reader).Peek(0x13091020, 0x2) D:/Program Files (x86)/Go/src/bufio/bufio.go:144 +0x6d github.com/gorilla/websocket.(*Conn).read(0x13d2a000, 0x2) D:/Program Files (x86)/Go/bin/pkg/mod/github.com/gorilla/websocket@v1.5.0/conn.go:371 +0x30 github.com/gorilla/websocket.(*Conn).advanceFrame(0x13d2a000) D:/Program Files (x86)/Go/bin/pkg/mod/github.com/gorilla/websocket@v1.5.0/conn.go:809 +0xae github.com/gorilla/websocket.(*Conn).NextReader(0x13d2a000) D:/Program Files (x86)/Go/bin/pkg/mod/github.com/gorilla/websocket@v1.5.0/conn.go:1009 +0xb5 github.com/gorilla/websocket.(*Conn).ReadMessage(0x13d2a000) D:/Program Files (x86)/Go/bin/pkg/mod/github.com/gorilla/websocket@v1.5.0/conn.go:1093 +0x25 go-study/models.recvProc(0x13264140)
06-02
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

莫忘输赢

莫忘输赢 - 收钱袋

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值