「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Go の net/rpc パッケージを使用して Web ページから JSON-RPC リクエストを行う方法

Go の net/rpc パッケージを使用して Web ページから JSON-RPC リクエストを行う方法

2024 年 11 月 22 日に公開
ブラウズ:248

How to Make JSON-RPC Requests from a Web Page Using Go\'s net/rpc Package?

Web ページから JSON-RPC リクエストを行う

Go の net/rpc および net/rpc/jsonrpc パッケージは、JSON を使用して Go プロセス間で通信する方法を提供します。 -RPC。ただし、標準ライブラリのみを使用した Web ページから JSON-RPC サーバーへの接続は直接サポートされていません。サーバーは HTTP クライアントが CONNECT リクエストを発行することを期待していますが、Web ブラウザや cURL などのコマンドライン ツールは通常 POST リクエストを使用します。

カスタム HTTP アダプタ

これに対処するには、次のように作成できます。 HTTP リクエストとレスポンスの間の変換を処理するカスタム HTTP アダプターと、JSON-RPC サーバーによって使用される ServerCodec。

Code例

カスタム HTTP アダプターとテスト サービスの例を次に示します。

import (
    "bytes"
    "fmt"
    "io"
    "io/ioutil"
    "log"
    "net"
    "net/http"
    "net/rpc"
    "net/rpc/jsonrpc"
    "testing"
)

// adapt HTTP connection to ReadWriteCloser
type HttpConn struct {
    in  io.Reader
    out io.Writer
}

func (c *HttpConn) Read(p []byte) (n int, err error)  { return c.in.Read(p) }
func (c *HttpConn) Write(d []byte) (n int, err error) { return c.out.Write(d) }
func (c *HttpConn) Close() error                      { return nil }

// our service
type CakeBaker struct{}

func (cb *CakeBaker) BakeIt(n int, msg *string) error {
    *msg = fmt.Sprintf("your cake has been bacon (%d)", n)
    return nil
}

func TestHTTPServer(t *testing.T) {

    fmt.Printf("TestHTTPServer\n")

    cb := &CakeBaker{}

    server := rpc.NewServer()
    server.Register(cb)

    listener, e := net.Listen("tcp", ":4321")
    if e != nil {
        log.Fatal("listen error:", e)
    }
    defer listener.Close()

    go http.Serve(listener, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {

        if r.URL.Path == "/bake-me-a-cake" {
            serverCodec := jsonrpc.NewServerCodec(&HttpConn{in: r.Body, out: w})
            w.Header().Set("Content-type", "application/json")
            w.WriteHeader(200)
            err := server.ServeRequest(serverCodec)
            if err != nil {
                log.Printf("Error while serving JSON request: %v", err)
                http.Error(w, "Error while serving JSON request, details have been logged.", 500)
                return
            }
        }

    }))

    resp, err := http.Post("http://localhost:4321/bake-me-a-cake", "application/json", bytes.NewBufferString(
        `{"jsonrpc":"2.0","id":1,"method":"CakeBaker.BakeIt","params":[10]}`,
    ))
    if err != nil {
        panic(err)
    }

    defer resp.Body.Close()

    b, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        panic(err)
    }

    fmt.Printf("returned JSON: %s\n", string(b))
}

このアダプターを使用すると、POST リクエストを受け入れ、標準の JSON-RPC プロトコルを使用して処理する JSON-RPC サーバーを作成できます。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3