mirror of
https://github.com/astaxie/beego.git
synced 2025-06-12 21:50:40 +00:00
add httplib support like http.client
This commit is contained in:
78
docs/zh/HttpLib.md
Normal file
78
docs/zh/HttpLib.md
Normal file
@ -0,0 +1,78 @@
|
||||
## 方便的http客户端
|
||||
我们经常会使用Go来请求其他API应用,例如你使用beego开发了一个RESTFul的API应用,那么如果来请求呢?当然可以使用`http.Client`来实现,但是需要自己来操作很多步骤,自己需要考虑很多东西,所以我就基于net下的一些包实现了这个简便的http客户端工具。
|
||||
|
||||
该工具的主要特点:
|
||||
|
||||
- 链式操作
|
||||
- 超时控制
|
||||
- 方便的解析
|
||||
- 可控的debug
|
||||
|
||||
## 例子
|
||||
我们上次开发的RESTful应用,最后我写过如何通过curl来进行测试,那么下面一一对每个操作如何用httplib来操作进行展示
|
||||
|
||||
- 添加一个对象:
|
||||
|
||||
`curl -X POST -d '{"Score":1337,"PlayerName":"Sean Plott"}' http://127.0.0.1:8080/object`
|
||||
|
||||
返回一个相应的objectID:astaxie1373349756660423900
|
||||
|
||||
str,err:=beego.Post("http://127.0.0.1:8080/object").Body(`{"Score":1337,"PlayerName":"Sean Plott"}`).String()
|
||||
if err != nil{
|
||||
println(err)
|
||||
}
|
||||
|
||||
- 查询一个对象
|
||||
|
||||
`curl -X GET http://127.0.0.1:8080/object/astaxie1373349756660423900`
|
||||
|
||||
var object Obeject
|
||||
err:=beego.Get("http://127.0.0.1:8080/object/astaxie1373349756660423900").ToJson(&object)
|
||||
if err != nil{
|
||||
println(err)
|
||||
}
|
||||
|
||||
- 查询全部的对象
|
||||
|
||||
`curl -X GET http://127.0.0.1:8080/object`
|
||||
|
||||
var objects []Object
|
||||
err:=beego.Get("http://127.0.0.1:8080/object").ToJson(&objects)
|
||||
if err != nil{
|
||||
println(err)
|
||||
}
|
||||
|
||||
- 更新一个对象
|
||||
|
||||
`curl -X PUT -d '{"Score":10000}'http://127.0.0.1:8080/object/astaxie1373349756660423900`
|
||||
|
||||
str,err:=beego.Put("http://127.0.0.1:8080/object/astaxie1373349756660423900").Body(`{"Score":10000}`).String()
|
||||
if err != nil{
|
||||
println(err)
|
||||
}
|
||||
|
||||
- 删除一个对象
|
||||
|
||||
`curl -X DELETE http://127.0.0.1:8080/object/astaxie1373349756660423900`
|
||||
|
||||
str,er:=beego.Delete("http://127.0.0.1:8080/object/astaxie1373349756660423900").String()
|
||||
if err != nil{
|
||||
println(err)
|
||||
}
|
||||
|
||||
## 开启调试模式
|
||||
用户可以开启调试打印request信息,默认是关闭模式
|
||||
|
||||
beego.Post(url).Debug(true)
|
||||
|
||||
## ToFile、ToXML、ToJson
|
||||
上面我演示了Json的解析,其实还有直接保存为文件的ToFile操作,解析XML的ToXML操作
|
||||
|
||||
|
||||
## 设置链接超时和读写超时
|
||||
默认都设置为60秒,用户可以通过函数来设置相应的超时时间
|
||||
|
||||
beego.Get(url).SetTimeout(100*time.Second,100*time.Second)
|
||||
|
||||
|
||||
更加详细的请参考[API接口](http://gowalker.org/github.com/astaxie/beego)
|
@ -44,6 +44,7 @@ beego是一个类似tornado的Go应用框架,采用了RESTFul的方式来实
|
||||
* [beego案例](Application.md)
|
||||
* [热升级](HotUpdate.md)
|
||||
* [API应用开发入门](API.md)
|
||||
* [HTTPLIB客户端](HttpLib.md)
|
||||
|
||||
|
||||
# API接口
|
||||
|
0
docs/zh/quickstart/cache.md
Normal file
0
docs/zh/quickstart/cache.md
Normal file
0
docs/zh/quickstart/configs.md
Normal file
0
docs/zh/quickstart/configs.md
Normal file
0
docs/zh/quickstart/controller.md
Normal file
0
docs/zh/quickstart/controller.md
Normal file
0
docs/zh/quickstart/createapp.md
Normal file
0
docs/zh/quickstart/createapp.md
Normal file
0
docs/zh/quickstart/deploy.md
Normal file
0
docs/zh/quickstart/deploy.md
Normal file
0
docs/zh/quickstart/devmode.md
Normal file
0
docs/zh/quickstart/devmode.md
Normal file
0
docs/zh/quickstart/filter.md
Normal file
0
docs/zh/quickstart/filter.md
Normal file
0
docs/zh/quickstart/flash.md
Normal file
0
docs/zh/quickstart/flash.md
Normal file
0
docs/zh/quickstart/logs.md
Normal file
0
docs/zh/quickstart/logs.md
Normal file
0
docs/zh/quickstart/miniapp.md
Normal file
0
docs/zh/quickstart/miniapp.md
Normal file
0
docs/zh/quickstart/params.md
Normal file
0
docs/zh/quickstart/params.md
Normal file
0
docs/zh/quickstart/request.md
Normal file
0
docs/zh/quickstart/request.md
Normal file
0
docs/zh/quickstart/response.md
Normal file
0
docs/zh/quickstart/response.md
Normal file
0
docs/zh/quickstart/router.md
Normal file
0
docs/zh/quickstart/router.md
Normal file
0
docs/zh/quickstart/session.md
Normal file
0
docs/zh/quickstart/session.md
Normal file
0
docs/zh/quickstart/staticfile.md
Normal file
0
docs/zh/quickstart/staticfile.md
Normal file
0
docs/zh/quickstart/template.md
Normal file
0
docs/zh/quickstart/template.md
Normal file
0
docs/zh/quickstart/third.md
Normal file
0
docs/zh/quickstart/third.md
Normal file
Reference in New Issue
Block a user