Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

GoRequest -- Simplified HTTP client ( inspired by nodejs SuperAgent )

License

NotificationsYou must be signed in to change notification settings

parnurzeal/gorequest

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GoRequest -- Simplified HTTP client ( inspired by famous SuperAgent lib in Node.js )

GopherGoRequest

"Shooting Requests like a Machine Gun" - Gopher

Sending request has never been as fun nor easier than this. It comes with lots of features:

  • Get/Post/Put/Head/Delete/Patch/Options
  • Set - simple header setting
  • JSON - made it simple with JSON string as a parameter
  • Multipart-Support - send data and files as multipart request
  • Proxy - sending request via proxy
  • Timeout - setting timeout for a request
  • TLSClientConfig - taking control over tls where at least you can disable security check for https
  • RedirectPolicy
  • Cookie - setting cookies for your request
  • CookieJar - automatic in-memory cookiejar
  • BasicAuth - setting basic authentication header
  • more to come..

Installation

$ go get github.com/parnurzeal/gorequest

Documentation

SeeGo Doc orGo Walker for usage and details.

Status

Drone Build StatusTravis Build Status

Why should you use GoRequest?

GoRequest makes thing much more simple for you, making http client more awesome and fun like SuperAgent + golang style usage.

This is what you normally do for a simple GET without GoRequest:

resp,err:=http.Get("http://example.com/")

With GoRequest:

request:=gorequest.New()resp,body,errs:=request.Get("http://example.com/").End()

Or below if you don't want to reuse it for other requests.

resp,body,errs:=gorequest.New().Get("http://example.com/").End()

How about getting control over HTTP client headers, redirect policy, and etc. Things can quickly get more complicated in golang. You need to create a Client, set headers in a different command, ... just to do only oneGET

client:=&http.Client{CheckRedirect:redirectPolicyFunc,}req,err:=http.NewRequest("GET","http://example.com",nil)req.Header.Add("If-None-Match",`W/"wyzzy"`)resp,err:=client.Do(req)

Why make things ugly while you can just do it as follows:

request:=gorequest.New()resp,body,errs:=request.Get("http://example.com").RedirectPolicy(redirectPolicyFunc).Set("If-None-Match",`W/"wyzzy"`).End()

DELETE,HEAD,POST,PUT,PATCH are now supported and can be used in the same way asGET:

request:=gorequest.New()resp,body,errs:=request.Post("http://example.com").End()// PUT -> request.Put("http://example.com").End()// DELETE -> request.Delete("http://example.com").End()// HEAD -> request.Head("http://example.com").End()// ANYTHING -> request.CustomMethod("TRACE", "http://example.com").End()

JSON

For aJSON POST with standard libraries, you might need to marshal map data structure to json format, set headers to 'application/json' (and other headers if you need to) and declare http.Client. So, your code becomes longer and harder to maintain:

m:=map[string]interface{}{"name":"backy","species":"dog",}mJson,_:=json.Marshal(m)contentReader:=bytes.NewReader(mJson)req,_:=http.NewRequest("POST","http://example.com",contentReader)req.Header.Set("Content-Type","application/json")req.Header.Set("Notes","GoRequest is coming!")client:=&http.Client{}resp,_:=client.Do(req)

Compared to our GoRequest version, JSON is for sure a default. So, it turns out to be just one simple line!:

request:=gorequest.New()resp,body,errs:=request.Post("http://example.com").Set("Notes","gorequst is coming!").Send(`{"name":"backy", "species":"dog"}`).End()

Moreover, it also supports struct type. So, you can have a funMix & Match sending the different data types for your request:

typeBrowserVersionSupportstruct {ChromestringFirefoxstring}ver:=BrowserVersionSupport{Chrome:"37.0.2041.6",Firefox:"30.0" }request:=gorequest.New()resp,body,errs:=request.Post("http://version.com/update").Send(ver).Send(`{"Safari":"5.1.10"}`).End()

Not only for Send() but Query() is also supported. Just give it a try! :)

Callback

Moreover, GoRequest also supports callback function. This gives you much more flexibility on using it. You can use it any way to match your own style!Let's see a bit of callback example:

funcprintStatus(resp gorequest.Response,bodystring,errs []error){fmt.Println(resp.Status)}gorequest.New().Get("http://example.com").End(printStatus)

Multipart/Form-Data

You can specify the content-type of the request to typemultipart to send all data asmultipart/form-data. This feature also allows you to send (multiple) files! Check the examples below!

gorequest.New().Post("http://example.com/").Type("multipart").Send(`{"query1":"test"}`).End()

TheSendFile function acceptsstrings as path to a file,[]byte slice or even aos.File! You can also combine them to send multiple files with either custom name and/or custom fieldname:

f,_:=filepath.Abs("./file2.txt")bytesOfFile,_:=ioutil.ReadFile(f)gorequest.New().Post("http://example.com/").Type("multipart").SendFile("./file1.txt").SendFile(bytesOfFile,"file2.txt","my_file_fieldname").End()

Check the docs forSendFile to get more information about the types of arguments.

Headers

When setting one header to the request, theSet method can be used:

gorequest.New().Post("/gamelist").Set("Accept","application/json").End()

This will clear all headers currently attached to a request and add the specified header.

If there are multiple headers that must be appended to the request before sending, useAppendHeader. These can be chained together to add additional headers to the request:

gorequest.New().Post("/gamelist").AppendHeader("Accept","application/json").AppendHeader("Accept","text/plain").End()

See the docs for theSet andAppendHeader methods for information about parameter and return types.

Proxy

In the case when you are behind proxy, GoRequest can handle it easily with Proxy func:

request:=gorequest.New().Proxy("http://proxy:999")resp,body,errs:=request.Get("http://example-proxy.com").End()// To reuse same client with no_proxy, use empty string:resp,body,errs=request.Proxy("").Get("http://example-no-proxy.com").End()

Basic Authentication

To add a basic authentication header:

request:=gorequest.New().SetBasicAuth("username","password")resp,body,errs:=request.Get("http://example-proxy.com").End()

Timeout

Timeout can be set in any time duration using time package:

request:=gorequest.New().Timeout(2*time.Millisecond)resp,body,errs:=request.Get("http://example.com").End()

Timeout func defines both dial + read/write timeout to the specified time parameter.

EndBytes

Thanks to @jaytaylor, we now have EndBytes to use when you want the body as bytes.

The callbacks work the same way as withEnd, except that a byte array is used instead of a string.

resp,bodyBytes,errs:=gorequest.New().Get("http://example.com/").EndBytes()

EndStruct

We now have EndStruct to use when you want the body as struct.

The callbacks work the same way as withEnd, except that a struct is used instead of a string.

Supposing the URLhttp://example.com/ returns the body{"hey":"you"}

heyYoustruct {Heystring`json:"hey"`}varheyYouheyYouresp,_,errs:=gorequest.New().Get("http://example.com/").EndStruct(&heyYou)

Retry

Supposing you need retry 3 times, with 5 seconds between each attempt when gets a BadRequest or a InternalServerError

request:=gorequest.New()resp,body,errs:=request.Get("http://example.com/").Retry(3,5*time.Second,http.StatusBadRequest,http.StatusInternalServerError).End()

Handling Redirects

Redirects can be handled with RedirectPolicy which behaves similarly tonet/http Client'sCheckRedirectfunction. Simply specify a functionwhich takes the Request about to be made and a slice of previous Requests inorder of oldest first. When this function returns an error, the Request is notmade.

For example to redirect only to https endpoints:

request:=gorequest.New()resp,body,errs:=request.Get("http://example.com/").RedirectPolicy(func(reqRequest,via []*Request)error {ifreq.URL.Scheme!="https" {returnhttp.ErrUseLastResponse                      }                    }).End()

Clone

You can reuse settings of a Request by cloning itbefore making any requests. This can be useful if you wish to re-use the SuperAgent across multiple requests without worrying about concurrency or having too many Transports being created.

Clones will copy the same settings (headers, query, etc..), but will only shallow copy any "Data" given to it. They will also share the same Transport and http.Client.

baseRequest:=gorequest.New()// apply anything you want to these settings. Eg:baseRequest.Timeout(10*time.Millisecond).BasicAuth("user","password")// then reuse the base request elsewhere, cloning before modifying or using it.resp,body,errs:=baseRequest.Clone().Get("http://exmaple.com/").End()

Debug

For debugging, GoRequest leverageshttputil to dump details of every request/response. (Thanks to @dafang)

You can just useSetDebug or environment variableGOREQUEST_DEBUG=0|1 to enable/disable debug mode andSetLogger to set your own choice of logger.

Thanks to @QuentinPerez, we can see even how gorequest is compared to CURL by usingSetCurlCommand.

Noted

As the underlying gorequest is based on http.Client in most use cases, gorequest.New() should be called once and reuse gorequest as much as possible.

Contributing to GoRequest:

If you find any improvement or issue you want to fix, feel free to send me a pull request with testing.

Thanks to all contributors thus far:

Contributors
https://github.com/alaingilbert
https://github.com/austinov
https://github.com/coderhaoxin
https://github.com/codegoalie
https://github.com/dafang
https://github.com/davyzhang
https://github.com/dickeyxxx
https://github.com/figlief
https://github.com/fraenky8
https://github.com/franciscocpg
https://github.com/heytitle
https://github.com/hownowstephen
https://github.com/kemadz
https://github.com/killix
https://github.com/jaytaylor
https://github.com/na-ga
https://github.com/piotrmiskiewicz
https://github.com/pencil001
https://github.com/pkopac
https://github.com/quangbuule
https://github.com/QuentinPerez
https://github.com/smallnest
https://github.com/WaveCutz
https://github.com/xild
https://github.com/yangmls
https://github.com/6david9

Also, co-maintainer is needed here. If anyone is interested, please email me (parnurzeal at gmail.com)

Credits

  • Renee French - the creator of Gopher mascot
  • Wisi Mongkhonsrisawat for providing an awesome GoRequest's Gopher image :)

License

GoRequest is MIT License.


[8]ページ先頭

©2009-2025 Movatter.jp