"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo realizar solicitudes JSON-RPC desde una página web utilizando el paquete net/rpc de Go?

¿Cómo realizar solicitudes JSON-RPC desde una página web utilizando el paquete net/rpc de Go?

Publicado el 2024-11-22
Navegar:843

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

Realizar solicitudes JSON-RPC desde una página web

Los paquetes net/rpc y net/rpc/jsonrpc en Go proporcionan una manera de comunicarse entre procesos de Go usando JSON -RPC. Sin embargo, no se admite directamente la conexión a un servidor JSON-RPC desde una página web utilizando solo la biblioteca estándar. Si bien el servidor espera que un cliente HTTP emita una solicitud CONNECT, los navegadores web y las herramientas de línea de comandos como cURL suelen utilizar solicitudes POST.

Adaptador HTTP personalizado

Para solucionar este problema, puede crear un adaptador HTTP personalizado para manejar la conversión entre solicitudes y respuestas HTTP y un ServerCodec, que utiliza el servidor JSON-RPC.

Código Ejemplo

A continuación se muestra un ejemplo de un adaptador HTTP personalizado y un servicio de prueba:

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))
}

Al utilizar este adaptador, puede crear un servidor JSON-RPC que acepte solicitudes POST y las procese utilizando el protocolo JSON-RPC estándar.

Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3