Golang 筆記
  • Introduction
  • 安裝Golang
    • 本地編譯與安裝第三方套件
    • 第一個 GO 程式
    • export 與 import
    • 使用 go mod
  • 基本工具
  • DataBase操作
    • MySQL
    • 使用 ORM
    • MongoDB
  • 基本語法
    • Variable
    • BSON
    • JSON
    • 時間相關
    • Interface
    • Error
    • 型別
    • 字串
    • defer
    • panic, recover
    • Channel 與Goroutine
      • 讀寫鎖
      • for select 與 for range
      • UnBuffered channel 與 Buffered channel
    • Function
    • pointer
    • regExp
    • fmt
    • Make vs New
    • struct
    • Array, Slice 陣列
    • map
  • 核心模組
    • Reflect
    • File
    • Signal
    • BuiltIn
    • Sync
    • IO
    • Sort
    • http
    • crypto
    • context
  • 第三方模組
    • Dom Parser
    • gin 框架
    • Websocket
    • Iris框架
      • 讀取 Body 資料
      • 相關範例
    • Fiber 框架
    • 自動重啟 server 工具
    • go-jwt
  • 測試
  • 原始碼解析
  • 常見問題
    • 資料存取不正確
    • Data races
Powered by GitBook
On this page

Was this helpful?

  1. 第三方模組

Websocket

package main

import (
	"flag"
	"log"
	"net/http"

	"github.com/gorilla/websocket"
)

var addr = flag.String("addr", "localhost:8010", "http service address")

var upgrader = websocket.Upgrader{
	CheckOrigin: func(r *http.Request) bool { return true },// 讓不同 port 能連到
} 

func echo(w http.ResponseWriter, r *http.Request) {
	c, err := upgrader.Upgrade(w, r, nil)
	if err != nil {
		log.Print("upgrade:", err)
		return
	}
	defer c.Close()
	for {
		mt, message, err := c.ReadMessage()
		if err != nil {
			log.Println("read:", err)
			break
		}
		log.Printf("recv: %s", message)
		err = c.WriteMessage(mt, message)
		if err != nil {
			log.Println("write:", err)
			break
		}
	}
}
func main() {

	http.HandleFunc("/echo", echo)
	log.Fatal(http.ListenAndServe(*addr, nil))
}

不能跟 app 寫在同一個程式,不像 nodejs 可以跟 http server 寫在一起

client.js

import React, { useEffect, useState } from "react";

function App() {
  const [ws, setWs] = useState("");
  const [text, setText] = useState("");

  const handleOpen = () => {
    const _ws = new WebSocket("ws://localhost:8010/echo");
    setWs(_ws);
    _ws.onopen = function (evt) {
      console.log("OPEN");
    };
  };
  
  const handleSend = () => {
    ws.send(text);
  };
  
  return (
    <div className="App">
      <header className="App-header">
        test
        <input onChange={(e) => setText(e.target.value)}></input>
        <button onClick={handleOpen}>Open</button>
        <button onClick={handleSend}>Send</button>
      </header>
    </div>
  );
}

export default App;
Previousgin 框架NextIris框架

Last updated 4 years ago

Was this helpful?