Skip to content

resty

10,341 1 4 MIT
v3.0.0-alpha.6 (2 Jan 2025) May 21 2020 58.1 thousand (month)

Resty is an HTTP and REST client library for Go. It is designed to be simple and easy to use, while still providing a lot of powerful features. One of the main benefits of using Resty is that it allows you to make HTTP requests with minimal boilerplate code, while still providing a lot of flexibility and control over the requests.

One of the key features of Resty is its use of chaining. This allows you to chain together multiple methods to build up a request, making the code more readable and easy to understand. For example, you can chain together the R().SetHeader("Accept", "application/json") method to set the Accept header and R().SetQueryParam("param1", "value1") to add a query parameter to the request.

Resty also provides a lot of convenience functions for making common types of requests, such as Get, Post, Put, and Delete. This can be useful if you need to make a simple request quickly and don't want to spend a lot of time configuring the request. Additionally, Resty also provides a way to set a timeout for the request, in case the server takes too long to respond.

Resty also supports HTTP/2 and advanced features like multipart file upload, request and response middlewares, request hooks, and many others.

Overall, Resty is a good choice if you're looking for a simple and easy-to-use HTTP client library for Go. It's a good fit for projects that don't require a lot of customization and need a quick way to make HTTP requests.

Example Use


package main

// establish session client
client := resty.New()
// set proxy for the session
client.SetProxy("http://proxyserver:8888")
// set retries
client.
    // Set retry count to non zero to enable retries
    SetRetryCount(3).
    // You can override initial retry wait time.
    // Default is 100 milliseconds.
    SetRetryWaitTime(5 * time.Second).
    // MaxWaitTime can be overridden as well.
    // Default is 2 seconds.
    SetRetryMaxWaitTime(20 * time.Second).
    // SetRetryAfter sets callback to calculate wait time between retries.
    // Default (nil) implies exponential backoff with jitter
    SetRetryAfter(func(client *resty.Client, resp *resty.Response) (time.Duration, error) {
        return 0, errors.New("quota exceeded")
    })

// Make GET request
resp, err := client.R().
    // we can set query
    SetQueryParams(map[string]string{
        "query": "foo",
    }).
    // and headers
    SetHeader("Accept", "application/json").
    Get("https://httpbin.org/get")

// Make Post request
resp, err := client.R().
    // JSON data
    SetHeader("Content-Type", "application/json").
    SetBody(`{"username":"testuser", "password":"testpass"}`).
    // or Form Data
    SetFormData(map[string]string{
      "username": "jeeva",
      "password": "mypass",
    }).
    Post("https://httpbin.org/post")

// resty also support request and response middlewares
// which allow easy modification of outgoing requests and incoming responses
client.OnBeforeRequest(func(c *resty.Client, req *resty.Request) error {
    // Now you have access to Client and current Request object
    // manipulate it as per your need

    return nil  // if its success otherwise return error
  })

// Registering Response Middleware
client.OnAfterResponse(func(c *resty.Client, resp *resty.Response) error {
    // Now you have access to Client and current Response object
    // manipulate it as per your need

    return nil  // if its success otherwise return error
  })

Alternatives / Similar


req
4,346 v3.49.1 (12 days ago) Aug 12 2023 compare

Other Languages

52,322 2.32.3 (7 months ago) Feb 14 2011 compare
15,288 3.11.11 (18 days ago) Jul 26 2019 compare
8,819 3.3.2 (1 year, 1 month ago) Dec 28 2012 compare
106,075 1.7.9 (14 days ago) Aug 29 2014 compare
13,513 0.28.1 (30 days ago) Jul 26 2019 compare
got
14,222 14.4.2 (4 months ago) Mar 27 2014 compare
4,052 v0.6.1 (10 months ago) Feb 23 2022 compare
16,601 10.1.1 (2 months ago) Aug 22 2011 compare
1,624 3.3.1 (1 year, 26 days ago) Dec 11 2011 compare
5,775 2.12.2 (28 days ago) Dec 19 2009 compare
702 2.8.3 (8 years ago) Jul 25 2009 compare
1,161 1.2.3 (2 days ago) Oct 31 2009 compare
5,826 0.22.0 (8 months ago) Jul 25 2009 compare
4,079 1.4.1 (1 year, 1 month ago) Oct 06 2009 compare
1,086 7.45.4 (24 days ago) Feb 25 2003 compare
984 1.4.7 (1 year, 7 months ago) May 06 2012 compare
1,751 0.7.1 (5 months ago) Feb 23 2022 compare
1,495 1.0.4 (2 years ago) Nov 22 2014 compare
23,055 7.9.1 (5 months ago) Nov 14 2011 compare
1,216 1.1.7 (4 years ago) Oct 25 2009 compare
1,933 v7.1.5 (3 months ago) Apr 28 2019 compare
587 23.11.0 (1 year, 2 months ago) Dec 28 2012 compare
897 1.0.2 (2 months ago) Sep 25 2013 compare
381 18.1.0 (4 months ago) Aug 06 2011 compare
507 1.1.4 (4 years ago) Apr 20 2010 compare
106 1.5.0 (8 months ago) Nov 09 2016 compare
3,573 v2.0.14 (26 days ago) Oct 06 2013 compare
731 0.9.2 (a month ago) Feb 23 2022 compare
1,916 1.3.0 (3 months ago) Nov 11 2011 compare
1,743 1.0.0 (8 months ago) Apr 14 2012 compare
3,011 0.12.0 (7 years ago) Mar 20 2015 compare
156 2.2.4 (3 years ago) Dec 22 2019 compare
Was this page helpful?