基于beego一键建立RESTFul应用

API应用开发入门

Go是很是适合用来开发API应用的,并且我认为也是Go相对于其余动态语言的最大优点应用。beego在开发API应用方面提供了很是强大和快速的工具,方便用户快速的创建API应用原型,专心业务逻辑就好了。 git

快速创建原型

bee快速开发工具提供了一个API应用创建的工具,在gopath/src下的任意目录执行以下命令就能够快速的创建一个API应用: github

bee api beeapi api

应用的目录结构

应用的目录结构以下所示: app

├── conf
│   └── app.conf
├── controllers
│   └── default.go
├── models
│    └── object.go
└── main.go

源码解析

  • app.conf里面主要针对API的配置以下:

autorender = false //API应用不须要模板渲染,因此关闭自动渲染 curl

copyrequestbody = true //RESTFul应用发送信息的时候是raw body,而不是普通的form表单,因此须要额外的读取body信息 工具

  • main.go文件主要针对RESTFul的路由注册

beego.RESTRouter("/object", &controllers.ObejctController{}) 开发工具

这个路由能够匹配以下的规则 测试

URL HTTP Verb Functionality
/object POST Creating Objects
/object/objectId GET Retrieving Objects
/object/objectId PUT Updating Objects
/object GET Queries
/object/objectId DELETE Deleting Objects
  • ObejctController实现了对应的方法:
type ObejctController struct {
    beego.Controller
}

func (this *ObejctController) Post(){

}

func (this *ObejctController) Get(){

}

func (this *ObejctController) Put(){

}

func (this *ObejctController) Delete(){

}
  • models里面实现了对应操做对象的增删改取等操做

测试

  • 添加一个对象: this

    curl -X POST -d '{"Score":1337,"PlayerName":"Sean Plott"}' http://127.0.0.1:8080/object url

    返回一个相应的objectID:astaxie1373349756660423900

  • 查询一个对象

    curl -X GET http://127.0.0.1:8080/object/astaxie1373349756660423900

  • 查询所有的对象

    curl -X GET http://127.0.0.1:8080/object

  • 更新一个对象

    curl -X PUT -d '{"Score":10000}'http://127.0.0.1:8080/object/astaxie1373349756660423900

  • 删除一个对象

    curl -X DELETE http://127.0.0.1:8080/object/astaxie1373349756660423900

相关文章
相关标签/搜索