Commit 0a967875 authored by astaxie's avatar astaxie

Merge pull request #757 from smallfish/develop

Add new function SetBasicAuth, and update README
parents ff9c8d94 6ae8bc1a
...@@ -6,53 +6,71 @@ httplib is an libs help you to curl remote url. ...@@ -6,53 +6,71 @@ httplib is an libs help you to curl remote url.
## GET ## GET
you can use Get to crawl data. you can use Get to crawl data.
import "httplib" import "github.com/astaxie/beego/httplib"
str, err := httplib.Get("http://beego.me/").String() str, err := httplib.Get("http://beego.me/").String()
if err != nil { if err != nil {
t.Fatal(err) // error
} }
fmt.Println(str) fmt.Println(str)
## POST ## POST
POST data to remote url POST data to remote url
b:=httplib.Post("http://beego.me/") req := httplib.Post("http://beego.me/")
b.Param("username","astaxie") req.Param("username","astaxie")
b.Param("password","123456") req.Param("password","123456")
str, err := b.String() str, err := req.String()
if err != nil { if err != nil {
t.Fatal(err) // error
} }
fmt.Println(str) fmt.Println(str)
## set timeout ## Set timeout
you can set timeout in request.default is 60 seconds.
set Get timeout: The default timeout is `60` seconds, function prototype:
httplib.Get("http://beego.me/").SetTimeout(100 * time.Second, 30 * time.Second) SetTimeout(connectTimeout, readWriteTimeout time.Duration)
Exmaple:
set post timeout: // GET
httplib.Get("http://beego.me/").SetTimeout(100 * time.Second, 30 * time.Second)
// POST
httplib.Post("http://beego.me/").SetTimeout(100 * time.Second, 30 * time.Second) httplib.Post("http://beego.me/").SetTimeout(100 * time.Second, 30 * time.Second)
- first param is connectTimeout.
- second param is readWriteTimeout
## debug ## Debug
if you want to debug the request info, set the debug on
If you want to debug the request info, set the debug on
httplib.Get("http://beego.me/").Debug(true) httplib.Get("http://beego.me/").Debug(true)
## support HTTPS client ## Set HTTP Basic Auth
if request url is https. You can set the client support TSL:
str, err := Get("http://beego.me/").SetBasicAuth("user", "passwd").String()
if err != nil {
// error
}
fmt.Println(str)
## Set HTTPS
If request url is https, You can set the client support TSL:
httplib.SetTLSClientConfig(&tls.Config{InsecureSkipVerify: true}) httplib.SetTLSClientConfig(&tls.Config{InsecureSkipVerify: true})
more info about the tls.Config please visit http://golang.org/pkg/crypto/tls/#Config More info about the `tls.Config` please visit http://golang.org/pkg/crypto/tls/#Config
## Set HTTP Version
some servers need to specify the protocol version of HTTP
httplib.Get("http://beego.me/").SetProtocolVersion("HTTP/1.1")
## Set Cookie
## set cookie
some http request need setcookie. So set it like this: some http request need setcookie. So set it like this:
cookie := &http.Cookie{} cookie := &http.Cookie{}
...@@ -60,21 +78,20 @@ some http request need setcookie. So set it like this: ...@@ -60,21 +78,20 @@ some http request need setcookie. So set it like this:
cookie.Value = "astaxie" cookie.Value = "astaxie"
httplib.Get("http://beego.me/").SetCookie(cookie) httplib.Get("http://beego.me/").SetCookie(cookie)
## upload file ## Upload file
httplib support mutil file upload, use `b.PostFile()`
httplib support mutil file upload, use `req.PostFile()`
b:=httplib.Post("http://beego.me/") req := httplib.Post("http://beego.me/")
b.Param("username","astaxie") req.Param("username","astaxie")
b.Param("password","123456") req.PostFile("uploadfile1", "httplib.pdf")
b.PostFile("uploadfile1", "httplib.pdf") str, err := req.String()
b.PostFile("uploadfile2", "httplib.txt")
str, err := b.String()
if err != nil { if err != nil {
t.Fatal(err) // error
} }
fmt.Println(str) fmt.Println(str)
## set HTTP version
some servers need to specify the protocol version of HTTP
httplib.Get("http://beego.me/").SetProtocolVersion("HTTP/1.1") See godoc for further documentation and examples.
\ No newline at end of file
* [godoc.org/github.com/astaxie/beego/httplib](https://godoc.org/github.com/astaxie/beego/httplib)
...@@ -147,6 +147,12 @@ func (b *BeegoHttpRequest) Setting(setting BeegoHttpSettings) *BeegoHttpRequest ...@@ -147,6 +147,12 @@ func (b *BeegoHttpRequest) Setting(setting BeegoHttpSettings) *BeegoHttpRequest
return b return b
} }
// SetBasicAuth sets the request's Authorization header to use HTTP Basic Authentication with the provided username and password.
func (b *BeegoHttpRequest) SetBasicAuth(username, password string) *BeegoHttpRequest {
b.req.SetBasicAuth(username, password)
return b
}
// SetEnableCookie sets enable/disable cookiejar // SetEnableCookie sets enable/disable cookiejar
func (b *BeegoHttpRequest) SetEnableCookie(enable bool) *BeegoHttpRequest { func (b *BeegoHttpRequest) SetEnableCookie(enable bool) *BeegoHttpRequest {
b.setting.EnableCookie = enable b.setting.EnableCookie = enable
......
...@@ -120,6 +120,18 @@ func TestWithCookie(t *testing.T) { ...@@ -120,6 +120,18 @@ func TestWithCookie(t *testing.T) {
} }
} }
func TestWithBasicAuth(t *testing.T) {
str, err := Get("http://httpbin.org/basic-auth/user/passwd").SetBasicAuth("user", "passwd").String()
if err != nil {
t.Fatal(err)
}
t.Log(str)
n := strings.Index(str, "authenticated")
if n == -1 {
t.Fatal("authenticated not found in response")
}
}
func TestWithUserAgent(t *testing.T) { func TestWithUserAgent(t *testing.T) {
v := "beego" v := "beego"
str, err := Get("http://httpbin.org/headers").SetUserAgent(v).String() str, err := Get("http://httpbin.org/headers").SetUserAgent(v).String()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment