🖥️ REST
The Fiber Client for Fiber v3 is a powerful HTTP client optimized for high performance and ease of use in server-side applications. Built atop the FastHTTP library, it inherits FastHTTP's high-speed HTTP protocol implementation. The client is designed for making both internal requests (within a microservices architecture) and external requests to other web services.
Features
- Lightweight & Fast: Due to its FastHTTP foundation, the Fiber Client is both lightweight and extremely performant.
- Flexible Configuration: Set client-level configurations (e.g., timeouts, headers) that apply to all requests, while still allowing overrides at the individual request level.
- Connection Pooling: Maintains a pool of persistent connections, minimizing the overhead of establishing new connections for each request.
- Timeouts & Retries: Supports request-level timeouts and configurable retries to handle transient errors gracefully.
Usage
Instantiate the Fiber Client with your desired configurations, then send requests:
package main
import (
"fmt"
"time"
"github.com/gofiber/fiber/v3/client"
)
func main() {
cc := client.New()
cc.SetTimeout(10 * time.Second)
// Send a GET request
resp, err := cc.Get("https://httpbin.org/get")
if err != nil {
panic(err)
}
fmt.Printf("Status: %d\n", resp.StatusCode())
fmt.Printf("Body: %s\n", string(resp.Body()))
}
Check out examples for more detailed usage examples.
type Client struct {
mu sync.RWMutex
fasthttp *fasthttp.Client
baseURL string
userAgent string
referer string
header *Header
params *QueryParam
cookies *Cookie
path *PathParam
debug bool
timeout time.Duration
// user-defined request hooks
userRequestHooks []RequestHook
// client package-defined request hooks
builtinRequestHooks []RequestHook
// user-defined response hooks
userResponseHooks []ResponseHook
// client package-defined response hooks
builtinResponseHooks []ResponseHook
jsonMarshal utils.JSONMarshal
jsonUnmarshal utils.JSONUnmarshal
xmlMarshal utils.XMLMarshal
xmlUnmarshal utils.XMLUnmarshal
cborMarshal utils.CBORMarshal
cborUnmarshal utils.CBORUnmarshal
cookieJar *CookieJar
// proxy
proxyURL string
// retry
retryConfig *RetryConfig
// logger
logger log.CommonLogger
}
New
New creates and returns a new Client object.
func New() *Client
NewWithClient
NewWithClient creates and returns a new Client object from an existing fasthttp.Client
.
func NewWithClient(c *fasthttp.Client) *Client
REST Methods
The following methods send HTTP requests using the configured client:
Get
Sends a GET request, similar to axios.
func (c *Client) Get(url string, cfg ...Config) (*Response, error)
Post
Sends a POST request, similar to axios.
func (c *Client) Post(url string, cfg ...Config) (*Response, error)
Put
Sends a PUT request, similar to axios.
func (c *Client) Put(url string, cfg ...Config) (*Response, error)
Patch
Sends a PATCH request, similar to axios.
func (c *Client) Patch(url string, cfg ...Config) (*Response, error)
Delete
Sends a DELETE request, similar to axios.
func (c *Client) Delete(url string, cfg ...Config) (*Response, error)
Head
Sends a HEAD request, similar to axios.
func (c *Client) Head(url string, cfg ...Config) (*Response, error)
Options
Sends an OPTIONS request, similar to axios.
func (c *Client) Options(url string, cfg ...Config) (*Response, error)
Custom
Sends a custom HTTP request, similar to axios, allowing you to specify any method.
func (c *Client) Custom(url, method string, cfg ...Config) (*Response, error)
Request Configuration
The Config
type helps configure request parameters. When setting the request body, JSON is used as the default serialization. The priority of the body sources is:
- Body
- FormData
- File
type Config struct {
Ctx context.Context
UserAgent string
Referer string
Header map[string]string
Param map[string]string
Cookie map[string]string
PathParam map[string]string
Timeout time.Duration
MaxRedirects int
Body any
FormData map[string]string
File []*File
}
R
R creates a new Request
object from the client's request pool. Use ReleaseRequest()
to return it to the pool when done.
func (c *Client) R() *Request
Hooks
Hooks allow you to add custom logic before a request is sent or after a response is received.
RequestHook
RequestHook returns user-defined request hooks.
func (c *Client) RequestHook() []RequestHook
ResponseHook
ResponseHook returns user-defined response hooks.
func (c *Client) ResponseHook() []ResponseHook
AddRequestHook
Adds one or more user-defined request hooks.
func (c *Client) AddRequestHook(h ...RequestHook) *Client
AddResponseHook
Adds one or more user-defined response hooks.
func (c *Client) AddResponseHook(h ...ResponseHook) *Client
JSON
JSONMarshal
Returns the JSON marshaler function used by the client.
func (c *Client) JSONMarshal() utils.JSONMarshal
JSONUnmarshal
Returns the JSON unmarshaller function used by the client.
func (c *Client) JSONUnmarshal() utils.JSONUnmarshal
SetJSONMarshal
Sets a custom JSON marshaler.
func (c *Client) SetJSONMarshal(f utils.JSONMarshal) *Client
SetJSONUnmarshal
Sets a custom JSON unmarshaller.
func (c *Client) SetJSONUnmarshal(f utils.JSONUnmarshal) *Client
XML
XMLMarshal
Returns the XML marshaler function used by the client.
func (c *Client) XMLMarshal() utils.XMLMarshal
XMLUnmarshal
Returns the XML unmarshaller function used by the client.
func (c *Client) XMLUnmarshal() utils.XMLUnmarshal
SetXMLMarshal
Sets a custom XML marshaler.
func (c *Client) SetXMLMarshal(f utils.XMLMarshal) *Client
SetXMLUnmarshal
Sets a custom XML unmarshaller.
func (c *Client) SetXMLUnmarshal(f utils.XMLUnmarshal) *Client
CBOR
CBORMarshal
Returns the CBOR marshaler function used by the client.
func (c *Client) CBORMarshal() utils.CBORMarshal
CBORUnmarshal
Returns the CBOR unmarshaller function used by the client.
func (c *Client) CBORUnmarshal() utils.CBORUnmarshal
SetCBORMarshal
Sets a custom CBOR marshaler.
func (c *Client) SetCBORMarshal(f utils.CBORMarshal) *Client
SetCBORUnmarshal
Sets a custom CBOR unmarshaller.
func (c *Client) SetCBORUnmarshal(f utils.CBORUnmarshal) *Client
TLS
TLSConfig
Returns the client's TLS configuration. If none is set, it initializes a new one.
func (c *Client) TLSConfig() *tls.Config
SetTLSConfig
Sets the TLS configuration for the client.
func (c *Client) SetTLSConfig(config *tls.Config) *Client
SetCertificates
Adds client certificates to the TLS configuration.
func (c *Client) SetCertificates(certs ...tls.Certificate) *Client
SetRootCertificate
Adds one or more root certificates to the client's trust store.
func (c *Client) SetRootCertificate(path string) *Client
SetRootCertificateFromString
Adds one or more root certificates from a string.
func (c *Client) SetRootCertificateFromString(pem string) *Client
SetProxyURL
Sets a proxy URL for the client. All subsequent requests will use this proxy.
func (c *Client) SetProxyURL(proxyURL string) error
RetryConfig
Returns the retry configuration of the client.
func (c *Client) RetryConfig() *RetryConfig
SetRetryConfig
Sets the retry configuration for the client.
func (c *Client) SetRetryConfig(config *RetryConfig) *Client
BaseURL
BaseURL
BaseURL returns the base URL currently set in the client.
func (c *Client) BaseURL() string
SetBaseURL
Sets a base URL prefix for all requests made by the client.
func (c *Client) SetBaseURL(url string) *Client
Example:
cc := client.New()
cc.SetBaseURL("https://httpbin.org/")
resp, err := cc.Get("/get")
if err != nil {
panic(err)
}
fmt.Println(string(resp.Body()))
Click here to see the result
{
"args": {},
...
}
Headers
Header
Retrieves all values of a header key at the client level. The returned values apply to all requests.
func (c *Client) Header(key string) []string
AddHeader
Adds a single header to all requests initiated by this client.
func (c *Client) AddHeader(key, val string) *Client
SetHeader
Sets a single header, overriding any existing headers with the same key.
func (c *Client) SetHeader(key, val string) *Client
AddHeaders
Adds multiple headers at once, all applying to all future requests from this client.
func (c *Client) AddHeaders(h map[string][]string) *Client
SetHeaders
Sets multiple headers at once, overriding previously set headers.
func (c *Client) SetHeaders(h map[string]string) *Client
Query Parameters
Param
Returns the values for a given query parameter key.
func (c *Client) Param(key string) []string
AddParam
Adds a single query parameter for all requests.
func (c *Client) AddParam(key, val string) *Client
SetParam
Sets a single query parameter, overriding previously set values.
func (c *Client) SetParam(key, val string) *Client
AddParams
Adds multiple query parameters from a map of string slices.
func (c *Client) AddParams(m map[string][]string) *Client
SetParams
Sets multiple query parameters from a map, overriding previously set values.
func (c *Client) SetParams(m map[string]string) *Client
SetParamsWithStruct
Sets multiple query parameters from a struct. Nested structs are not currently supported.
func (c *Client) SetParamsWithStruct(v any) *Client
DelParams
Deletes one or more query parameters.
func (c *Client) DelParams(key ...string) *Client
UserAgent & Referer
SetUserAgent
Sets the user agent header for all requests.
func (c *Client) SetUserAgent(ua string) *Client
SetReferer
Sets the referer header for all requests.
func (c *Client) SetReferer(r string) *Client
Path Parameters
PathParam
Returns the value of a named path parameter, if set.
func (c *Client) PathParam(key string) string
SetPathParam
Sets a single path parameter.
func (c *Client) SetPathParam(key, val string) *Client
SetPathParams
Sets multiple path parameters at once.
func (c *Client) SetPathParams(m map[string]string) *Client
SetPathParamsWithStruct
Sets multiple path parameters from a struct.
func (c *Client) SetPathParamsWithStruct(v any) *Client
DelPathParams
Deletes one or more path parameters.
func (c *Client) DelPathParams(key ...string) *Client
Cookies
Cookie
Returns the value of a named cookie if set at the client level.
func (c *Client) Cookie(key string) string
SetCookie
Sets a single cookie for all requests.
func (c *Client) SetCookie(key, val string) *Client
Example:
cc := client.New()
cc.SetCookie("john", "doe")
resp, err := cc.Get("https://httpbin.org/cookies")
if err != nil {
panic(err)
}
fmt.Println(string(resp.Body()))
Click here to see the result
{
"cookies": {
"john": "doe"
}
}
SetCookies
Sets multiple cookies at once.
func (c *Client) SetCookies(m map[string]string) *Client
SetCookiesWithStruct
Sets multiple cookies from a struct.
func (c *Client) SetCookiesWithStruct(v any) *Client
DelCookies
Deletes one or more cookies.
func (c *Client) DelCookies(key ...string) *Client
Timeout
SetTimeout
Sets a default timeout for all requests, which can be overridden per request.
func (c *Client) SetTimeout(t time.Duration) *Client
Debugging
Debug
Enables debug-level logging output.
func (c *Client) Debug() *Client
DisableDebug
Disables debug-level logging output.
func (c *Client) DisableDebug() *Client
Cookie Jar
SetCookieJar
Assigns a cookie jar to the client to store and manage cookies across requests.
func (c *Client) SetCookieJar(cookieJar *CookieJar) *Client
Dial & Logger
SetDial
Sets a custom dial function.
func (c *Client) SetDial(dial fasthttp.DialFunc) *Client
SetLogger
Sets the logger instance used by the client.
func (c *Client) SetLogger(logger log.CommonLogger) *Client
Logger
Returns the current logger instance.
func (c *Client) Logger() log.CommonLogger
Reset
Reset
Clears and resets the client to its default state.
func (c *Client) Reset()
Default Client
Fiber provides a default client (created with New()
). You can configure it or replace it as needed.
C
C returns the default client.
func C() *Client
Get
Get is a convenience method that sends a GET request using the defaultClient
.
func Get(url string, cfg ...Config) (*Response, error)
Post
Post is a convenience method that sends a POST request using the defaultClient
.
func Post(url string, cfg ...Config) (*Response, error)
Put
Put is a convenience method that sends a PUT request using the defaultClient
.
func Put(url string, cfg ...Config) (*Response, error)
Patch
Patch is a convenience method that sends a PATCH request using the defaultClient
.
func Patch(url string, cfg ...Config) (*Response, error)
Delete
Delete is a convenience method that sends a DELETE request using the defaultClient
.
func Delete(url string, cfg ...Config) (*Response, error)
Head
Head sends a HEAD request using the defaultClient
, a convenience method.
func Head(url string, cfg ...Config) (*Response, error)
Options
Options is a convenience method that sends an OPTIONS request using the defaultClient
.
func Options(url string, cfg ...Config) (*Response, error)
Replace
Replace replaces the default client with a new one. It returns a function that can restore the old client.
Do not modify the default client concurrently.
func Replace(c *Client) func()