1
0
mirror of https://github.com/astaxie/beego.git synced 2025-01-12 05:17:12 +00:00
Beego/docs/zh/HttpLib.md
2013-08-03 22:20:09 +08:00

2.4 KiB
Raw Blame History

方便的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接口