package main import ( "log" "net/http" "strconv" "github.com/gorilla/websocket" ) var upgrader = websocket.Upgrader{ CheckOrigin: func(r *http.Request) bool { return true // Note: In production, you'd want to check the origin. }, } // handleWebSocket handles WebSocket requests from the peer. func handleWebSocket(w http.ResponseWriter, r *http.Request) { log.Println("Websocket connection!", r.RemoteAddr) conn, err := upgrader.Upgrade(w, r, nil) if err != nil { log.Println("Upgrade error:", err) return } defer conn.Close() for { mt, message, err := conn.ReadMessage() if err != nil { log.Println("Read error:", err) break } log.Printf("recv: %s", message) err = conn.WriteMessage(mt, message) if err != nil { log.Println("Write error:", err) break } } } // LoggingHandler logs requests and delegates them to the underlying handler. type LoggingHandler struct { handler http.Handler } func (lh *LoggingHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { log.Printf("Serving file: %s", r.URL.Path) lh.handler.ServeHTTP(w, r) } func main() { dir := "./" port := 9000 addr := ":" + strconv.Itoa(port) log.Printf("Starting server on %s", addr) // Set up file server and WebSocket endpoint fs := http.FileServer(http.Dir(dir)) loggingHandler := &LoggingHandler{handler: fs} http.Handle("/", loggingHandler) http.HandleFunc("/ws", handleWebSocket) // Configure and start the HTTP server server := &http.Server{ Addr: addr, Handler: nil, // nil uses the default ServeMux, which we configured above } log.Printf("Server is configured and serving on port %d...", port) log.Fatal(server.ListenAndServe()) }