2016-10-20 16:57:31 -07:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/labstack/echo"
|
|
|
|
|
|
|
|
"github.com/gorilla/websocket"
|
|
|
|
"github.com/labstack/echo/middleware"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
upgrader = websocket.Upgrader{}
|
|
|
|
)
|
|
|
|
|
|
|
|
func hello(c echo.Context) error {
|
|
|
|
ws, err := upgrader.Upgrade(c.Response(), c.Request(), nil)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer ws.Close()
|
|
|
|
|
|
|
|
for {
|
|
|
|
// Write
|
|
|
|
err := ws.WriteMessage(websocket.TextMessage, []byte("Hello, Client!"))
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Read
|
|
|
|
_, msg, err := ws.ReadMessage()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
fmt.Printf("%s\n", msg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
e := echo.New()
|
|
|
|
e.Use(middleware.Logger())
|
|
|
|
e.Use(middleware.Recover())
|
2016-10-23 13:37:04 -07:00
|
|
|
e.Use(middleware.Static("../public"))
|
2016-10-20 16:57:31 -07:00
|
|
|
e.GET("/ws", hello)
|
|
|
|
if err := e.Start(":1323"); err != nil {
|
2016-10-23 13:37:04 -07:00
|
|
|
e.Logger.Fatal(err)
|
2016-10-20 16:57:31 -07:00
|
|
|
}
|
|
|
|
}
|