TongYang b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
..
.gitignore b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
AUTHORS b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
LICENSE b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
README.md b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
client.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
client_clone.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
client_clone_legacy.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
compression.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
conn.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
conn_write.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
conn_write_legacy.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
doc.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
join.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
json.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
mask.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
mask_safe.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
prepared.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
proxy.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
server.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
trace.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
trace_17.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
util.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos
x_net_proxy.go b8d433d7df v1 %!s(int64=3) %!d(string=hai) anos

README.md

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

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.
github.com/gorilla golang.org/x/net
RFC 6455 Features
Passes Autobahn Test SuiteYesNo
Receive fragmented messageYesNo, see note 1
Send close messageYesNo
Send pings and receive pongsYesNo
Get the type of a received data messageYesYes, see note 2
Other Features
Compression ExtensionsExperimentalNo
Read message using io.ReaderYesNo, see note 3
Write message using io.WriteCloserYesNo, see note 3