Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/EddieIvan01/nic
π Nic is a HTTP request client with elegant and easy-to-use API
https://github.com/EddieIvan01/nic
Last synced: 2 months ago
JSON representation
π Nic is a HTTP request client with elegant and easy-to-use API
- Host: GitHub
- URL: https://github.com/EddieIvan01/nic
- Owner: EddieIvan01
- License: mpl-2.0
- Archived: true
- Created: 2019-05-14T15:08:15.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-11-28T15:47:05.000Z (about 5 years ago)
- Last Synced: 2024-08-05T06:01:21.024Z (6 months ago)
- Language: Go
- Homepage:
- Size: 1.08 MB
- Stars: 103
- Watchers: 3
- Forks: 18
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- xiao-awesome - nic
README
# Nic
![GitHub release](https://img.shields.io/github/release/eddieivan01/nic.svg?label=nic) ![GitHub issues](https://img.shields.io/github/issues/eddieivan01/nic.svg)
English | [δΈζ](https://github.com/EddieIvan01/nic/tree/master/docs/zh-cn.md)
Nic is a HTTP request client which has elegant, easy-to-use API
***
## Features
+ wrapper of HTTP std lib, provids elegant and easy-to-use API
+ keep session via `nic.Session` structure, `nic.Session` is go-routine safe
***
## Installation
To install nic, enter the following command
```
$ go get -v -u github.com/eddieivan01/nic
```***
## Quick start
Do a HTTP request like this
```go
resp, err := nic.Get("http://example.com", nil)
if err != nil {
log.Fatal(err.Error())
}
fmt.Println(resp.Text)
```***
## Documentation
## do a basic request
nic could do these methods' request
`"HEAD", "GET", "POST", "DELETE", "OPTIONS", "PUT", "PATCH"`
```go
import (
"fmt"
"github.com/eddieivan01/nic"
)func main() {
url := "http://example.com"
resp, err := nic.Get(url, nil)
if err != nil {
log.Fatal(err.Error())
}
fmt.Println(resp.Text)
}
```## post request with some form data
as you see, all requests' parameters are passed by `nic.H`, and the inner is saved in `nic.KV`, it's actually `map[string]interface{}`
```go
resp, err := nic.Post(url, nic.H{
Data : nic.KV{
"nic" : "nic",
},
Headers : nic.KV{
"X-Forwarded-For" : "127.0.0.1",
},
})
```## request with cookies
of course, you can also set it in Headers
```go
resp, err := nic.Get(url, nic.H{
Cookies : nic.KV{
"cookie" : "nic",
},
})
```## request with files
you can upload files with files' name + files' content which is `[]byte` type, and can also upload via local file path
while uploading a file, you can set `multipart` form's field name, filename and MIME type
for more convenient setting files parameters, you can invoke in a chain to set `filename` and MIME type
```go
resp, err := nic.Post(url, nic.H{
Files : nic.KV{
"file1": nic.File(
"nic.go",
[]byte("package nic")),
"file2": nic.FileFromPath("./nic.go").
MIME("text/plain").
FName("nic"),
},
})
```## request with JSON
```go
resp, err := nic.Post(url, nic.H{
JSON : nic.KV{
"nic" : "nic",
}
})
```## request with unencoded raw message
```go
resp, err := nic.Post(url, nic.H{
Raw : "post body which is unencoded",
})
```## using chunked transfer
The default is not to use chunked transfer
enable the `transfer-encoding: chunked`
```go
resp, _ := nic.Get(url, nic.H{
Chunked: true,
})
```## set query params
```go
resp, err := nic.Get(url, nic.H {
Params: nic.KV {
"a": "1",
},
})
```## all the parameters you could set
```go
H struct {
Params KV
Data KV
Raw string
Headers KV
Cookies KV
Auth KV
Proxy string
JSON KV
Files KVAllowRedirect bool
Timeout int64
Chunked bool
DisableKeepAlives bool
DisableCompression bool
SkipVerifyTLS bool
}
```## NOTICE
`nic.H` can only have one of the following four parameters
`H.Raw, H.Data, H.Files, H.JSON`
## request with session, which could handle server's `set-cookie` header
```go
session := nic.NewSession()
resp, err := session.Post("http://example.com/login", nic.H{
Data : nic.KV{
"uname" : "nic",
"passwd" : "nic",
},
})// ......
resp, err = session.Get("http://example.com/userinfo", nil)
```## handle response
```go
resp, _ := nic.Get(url, nil)
fmt.Println(resp.Text)
fmt.Println(resp.Bytes)
```## handle JSON response
```go
resp, _ := nic.Get(url, nil)type S struct {
P1 string `json:"p1"`
P2 string `json:"p2"`
}s := &S{}
err := resp.JSON(&s)if err == nil {
fmt.Println(s.P1, s.P2)
}
```## change response's encoding
`SetEncode` will convert `resp.Bytes` to `resp.Text` if encoding is changed every time be called
```go
resp, _ := nic.Get(url, nil)
err := resp.SetEncode("gbk")if err == nil {
fmt.Println(resp.Text)
}
```## save response's content as a file
```go
resp, _ := nic.Get("http://example.com/1.jpg", nil)
err := resp.SaveFile("1.jpg")
```***
## register a request/response hook
```go
session := nic.NewSession()
session.RegisterBeforeReqHook(func(r *http.Request) error {
r.URL.RawQuery = "nic=nic"
return nil
})
session.RegisterAfterRespHook(func(r *http.Response) error {
r.Header.Set("nic", "nic")
return nil
})session.Get(url, nil)
```***
## QA
+ Q:
How to get origin `*http.Request` from `nic.Session`?
A:
by `nic.Session.GetRequest` method
+ Q:
How to pass origin `*http.Response` to goquery-like DOM-parsing-libs from `nic.Response`?
A:
use `resp, _ := nic.Get(...); resp.Response` to access origin anonymous structure `*http.Response`; and `(*http.Response).Body's IO.Reader` has been saved, you can use `*http.Response` as if it were the original structure
+ Q:
Redirection is allowed 10 times by default, how could I increase the number?
A:
by access `nic.Session.Client` then change its CheckRedirect property
+ Q:
How to use the chunked transfer-encoding?
A:
by nic.H{Chunked: true}