名称 最后更新
..
.gitignore 正在载入提交数据...
AUTHORS 正在载入提交数据...
LICENSE 正在载入提交数据...
README.md 正在载入提交数据...
client.go 正在载入提交数据...
client_clone.go 正在载入提交数据...
client_clone_legacy.go 正在载入提交数据...
compression.go 正在载入提交数据...
conn.go 正在载入提交数据...
conn_write.go 正在载入提交数据...
conn_write_legacy.go 正在载入提交数据...
doc.go 正在载入提交数据...
go.mod 正在载入提交数据...
go.sum 正在载入提交数据...
join.go 正在载入提交数据...
json.go 正在载入提交数据...
mask.go 正在载入提交数据...
mask_safe.go 正在载入提交数据...
prepared.go 正在载入提交数据...
proxy.go 正在载入提交数据...
server.go 正在载入提交数据...
trace.go 正在载入提交数据...
trace_17.go 正在载入提交数据...
util.go 正在载入提交数据...
x_net_proxy.go 正在载入提交数据...

Gorilla WebSocket

GoDoc CircleCI

Gorilla WebSocket is a Go implementation of the WebSocket protocol.

Documentation

Status

The Gorilla WebSocket package provides a complete and tested implementation of the WebSocket protocol. The package API is stable.

Installation

go get github.com/gorilla/websocket

Protocol Compliance

The Gorilla WebSocket package passes the server tests in the Autobahn Test Suite using the application in the examples/autobahn subdirectory.

Gorilla WebSocket compared with other packages

github.com/gorilla golang.org/x/net
RFC 6455 Features
Passes Autobahn Test Suite Yes No
Receive fragmented message Yes No, see note 1
Send close message Yes No
Send pings and receive pongs Yes No
Get the type of a received data message Yes Yes, see note 2
Other Features
Compression Extensions Experimental No
Read message using io.Reader Yes No, see note 3
Write message using io.WriteCloser Yes No, see note 3

Notes:

  1. Large messages are fragmented in Chrome's new WebSocket implementation.
  2. The application can get the type of a received data message by implementing a Codec marshal function.
  3. The go.net io.Reader and io.Writer operate across WebSocket frame boundaries. Read returns when the input buffer is full or a frame boundary is encountered. Each call to Write sends a single frame message. The Gorilla io.Reader and io.WriteCloser operate on a single WebSocket message.