How do you handle HTTP client server logging in Go?
In Go, there are several ways to handle logging in an HTTP client or server. One common way is to use the log package from the standard library. Here's an example of how to use the log package to log HTTP requests and responses in a client:
Client Server Logging
Example
package main
import (
"log"
"net/http"
"net/http/httputil"
"time"
)
func main() {
client := &http.Client{
Timeout: 10 * time.Second,
}
req, err := http.NewRequest("GET", "https://example.com", nil)
if err != nil {
log.Fatal(err)
}
// Use httputil.DumpRequestOut to log the outgoing request
reqBytes, err := httputil.DumpRequestOut(req, true)
if err != nil {
log.Fatal(err)
}
log.Printf("Request: %s", reqBytes)
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
// Use httputil.DumpResponse to log the incoming response
respBytes, err := httputil.DumpResponse(resp, true)
if err != nil {
log.Fatal(err)
}
log.Printf("Response: %s", respBytes)
defer resp.Body.Close()
}
This code sets up an HTTP client with a timeout of 10 seconds, creates a GET request to https://example.com, logs the outgoing request using httputil.DumpRequestOut, sends the request using the client, logs the incoming response using httputil.DumpResponse, and finally closes the response body.
You can customize the logging output to suit your needs, for example by using different log levels or formats, or by logging additional information such as timestamps or request/response headers.
Most Helpful This Week
How to delete an element from a Slice in Golang?
How to create Slice using new keyword in Golang?
Polymorphism in Go Programming Language
Various examples of printing and formatting in Golang
Interface embedding and calling interface methods from another package in Go (Golang)
Contains, ContainsAny, Count and EqualFold string functions in Go Language
Most Helpful This Week
How to print struct variables data in Golang?What is GOPATH?Data encryption with AES-GCMHow to Convert string to integer type in Go?How to add and update elements in Map?Regular expression to extract domain from URLGolang Functions Returning Multiple ValuesHow to play and pause execution of goroutine?Split a character string based on change of characterClosures Functions in Golang