A fast, well-tested and widely used WebSocket implementation for Go.
Go to file
Gary Burd c50896b0f1 Update Travis config, Go 1.0 not supported. 2013-12-23 11:41:02 -08:00
examples Initial commit 2013-10-16 16:30:59 -07:00
.gitignore Initial commit 2013-10-16 16:30:59 -07:00
.travis.yml Update Travis config, Go 1.0 not supported. 2013-12-23 11:41:02 -08:00
LICENSE Initial commit 2013-10-16 16:30:59 -07:00
README.md Add more information to README.md. 2013-10-29 06:31:06 -07:00
client.go Modify client to work with Chrome debug server. 2013-12-21 08:44:58 -08:00
client_server_test.go Add subprotocol negotiation to Dialer. 2013-12-14 08:06:24 -08:00
conn.go Add subprotocol negotiation to Dialer. 2013-12-14 08:06:24 -08:00
conn_test.go Initial commit 2013-10-16 16:30:59 -07:00
doc.go Fix tabs in overview examples. 2013-12-20 15:57:02 -08:00
json.go Added WriteJSON/ReadJSON deprecated methods for backwards compatibility. 2013-10-27 18:27:32 -07:00
json_test.go Fix test for deprecated JSON funcs. 2013-10-27 18:33:40 -07:00
server.go Improve Upgrade documentation. 2013-12-20 14:54:49 -08:00
server_test.go Add Subprotocols helper function. 2013-10-26 06:52:30 -07:00
util.go Initial commit 2013-10-16 16:30:59 -07:00

README.md

Gorilla WebSocket

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 WebSockets Test Suite using the application in the examples/autobahn subdirectory.

Gorilla WebSocket compared with other packages

gorilla go.net
Protocol supportRFC 6455RFC 6455
Limit size of received messageYesNo
Send pings and receive pongsYesNo
Send close messageYesNo
Read message using io.ReaderYesNo, see note
Write message using io.WriteCloserYesNo, see note
Encode, decode JSON messageYesYes

Note: The go.net io.Reader and io.Writer operate across WebSocket message boundaries. Read returns when the input buffer is full or a message boundary is encountered, Each call to Write sends a message. The Gorilla io.Reader and io.WriteCloser operate on a single WebSocket message.