Maison > développement back-end > Golang > le corps du texte

Comment implémenter la journalisation des requêtes HTTP à l'aide de Go et http.Transport ?

王林
Libérer: 2023-07-23 11:22:56
original
851 Les gens l'ont consulté

Comment implémenter la journalisation des requêtes HTTP à l'aide de Go et http.Transport ?

Lorsque nous utilisons le langage Go pour effectuer des requêtes HTTP, nous rencontrons souvent des situations dans lesquelles nous devons enregistrer les informations détaillées de la requête, telles que l'enregistrement de l'URL demandée, de la méthode de requête, de l'en-tête de la requête, du corps de la requête, etc. Ces informations sont très utiles pour le débogage et le dépannage des problèmes. Cet article explique comment implémenter la journalisation des requêtes HTTP à l'aide de Go et http.Transport.

En langage Go, nous pouvons utiliser le package http pour effectuer des requêtes HTTP, et http.Transport est responsable de l'envoi et de la réception des requêtes et des réponses HTTP. En personnalisant la méthode RoundTrip de http.Transport, nous pouvons enregistrer le journal des demandes avant d'envoyer la demande et après avoir reçu la réponse.

Ce qui suit est un exemple de code :

package main

import (
    "log"
    "net/http"
    "net/http/httputil"
    "os"
    "time"
)

// LoggingTransport 实现了http.RoundTripper接口
type LoggingTransport struct {
    Transport http.RoundTripper
    Logger    *log.Logger
}

// RoundTrip 实现了http.RoundTripper接口的RoundTrip方法
func (t *LoggingTransport) RoundTrip(req *http.Request) (*http.Response, error) {
    startTime := time.Now()

    // 打印请求信息
    dump, err := httputil.DumpRequestOut(req, true)
    if err != nil {
        return nil, err
    }
    t.Logger.Println(string(dump))

    // 发送请求
    resp, err := t.Transport.RoundTrip(req)
    if err != nil {
        return nil, err
    }

    // 打印响应信息
    dump, err = httputil.DumpResponse(resp, true)
    if err != nil {
        return nil, err
    }
    t.Logger.Println(string(dump))

    // 计算请求耗时并打印
    duration := time.Since(startTime)
    t.Logger.Printf("Request took %s", duration)

    return resp, nil
}

func main() {
    // 创建自定义Transport
    transport := &LoggingTransport{
        Transport: http.DefaultTransport,
        Logger:    log.New(os.Stdout, "", log.LstdFlags),
    }

    // 创建自定义的http.Client
    client := &http.Client{
        Transport: transport,
    }

    // 创建自定义的http.Request
    req, err := http.NewRequest("GET", "http://www.example.com", nil)
    if err != nil {
        log.Fatal(err)
    }

    // 发送请求
    resp, err := client.Do(req)
    if err != nil {
        log.Fatal(err)
    }
    defer resp.Body.Close()

    // 处理响应
    // ...

}
Copier après la connexion

Dans le code ci-dessus, nous définissons d'abord un type LoggingTransport, qui implémente la méthode RoundTrip de l'interface http.RoundTripper. Dans cette méthode, nous obtenons d'abord l'heure actuelle comme heure de début de la requête, puis utilisons la méthode DumpRequestOut du package httputil pour convertir les informations de la requête en un tableau d'octets et les écrivons dans le fichier journal, puis envoyons la requête, puis utilisons la méthode DumpResponse pour convertir les informations de réponse en Le tableau d'octets est écrit dans le fichier journal, et enfin l'heure de la demande est calculée et imprimée.

Dans la fonction principale, nous créons un Transport et un Client personnalisés, les transmettons respectivement au champ Transport de http.Client et au dernier paramètre de la fonction http.NewRequest, puis envoyons la requête et traitons la réponse.

De cette façon, nous pouvons facilement implémenter la journalisation des requêtes HTTP. Les informations des journaux peuvent être sorties sur la console, écrites dans un fichier ou envoyées au système de collecte de journaux en fonction des besoins réels.

Résumé : Cet article explique comment implémenter la journalisation des requêtes HTTP à l'aide de Go et http.Transport. Nous personnalisons la méthode RoundTrip de http.Transport pour enregistrer les détails de la demande avant d'envoyer la demande et après avoir reçu la réponse, afin de faciliter le débogage et le dépannage. J'espère que cet article vous sera utile !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!