一键生成 后端 restful api
说明
主要用这个库 gitee.com/konyshe/gogo, 详情可以去查看说明文件。
只要连接好数据库表,不用 数据库的 models文件,就可以最简单的办法 生成 restful api.
原项目有一个小问题,
需要修改 源码 SQLUtils.go
239行修改
case "INT":
{
queryData[queryCount][a] = new(sql.NullInt64)
}
290 追加
case *sql.NullInt64:
result[columnsType[a].Name()] = *s
是因为涉及到 数据库里面 int 字段 允许为空,默认是null, 数据库读取的时候 会报错
sql: Scan error on column index 3, name "created_on": converting driver.Value type <nil> ("<nil>") to a int32: invalid syntax
demo
package main
import (
"net/http"
"strconv"
"gitee.com/konyshe/gogo"
)
func main() {
// 初始化数据库连接
if err := gogo.SQLInit("mysql", "root:1234567890@tcp(192.168.100.50:3306)/go?charset=utf8&parseTime=true", 10, 1); err != nil {
gogo.Log().Error(err.Error())
return
}
// 增
gogo.POST("/restful/:tablename", func(ctx *gogo.HTTPContext) {
affect, err := gogo.SQLInsert(
ctx.GetPathParam(":tablename"),
ctx.GetPostBody())
if err != nil {
gogo.Log().Error(err.Error())
ctx.WriteString(err.Error())
} else {
ctx.WriteString(strconv.FormatInt(affect, 10))
}
})
// 删
gogo.DELETE("/restful/:tablename/:id", func(ctx *gogo.HTTPContext) {
affect, err := gogo.SQLDelete(
ctx.GetPathParam(":tablename"),
"id="+ctx.GetPathParam(":id"))
if err != nil {
gogo.Log().Error(err.Error())
ctx.WriteString(err.Error())
} else {
ctx.WriteString(strconv.FormatInt(affect, 10))
}
})
// 改
gogo.PUT("/restful/:tablename/:id", func(ctx *gogo.HTTPContext) {
affect, err := gogo.SQLUpdate(
ctx.GetPathParam(":tablename"),
"id="+ctx.GetPathParam(":id"),
ctx.GetPostBody())
if err != nil {
gogo.Log().Error(err.Error())
ctx.WriteString(err.Error())
} else {
ctx.WriteString(strconv.FormatInt(affect, 10))
}
})
// 查
gogo.GET("/restful/:tablename/:id", func(ctx *gogo.HTTPContext) {
queryData, err := gogo.SQLQueryByMap(
"",
ctx.GetString("feilds"),
ctx.GetPathParam(":tablename"),
"id="+ctx.GetPathParam(":id"),
"", 0, 1)
if err != nil {
gogo.Log().Error(err.Error())
ctx.WriteString(err.Error())
} else {
ctx.WriteJSON(queryData)
}
})
// 查
gogo.GET("/restful/:tablename", func(ctx *gogo.HTTPContext) {
queryData, err := gogo.SQLQueryByMap(
ctx.GetString("columnname"),
ctx.GetString("feilds"),
ctx.GetPathParam(":tablename"),
ctx.GetString("where"),
ctx.GetString("order"),
ctx.GetInt("offset", 0),
ctx.GetInt("count", 10))
if err != nil {
gogo.Log().Error(err.Error())
ctx.WriteString(err.Error())
} else {
ctx.WriteJSON(queryData)
}
})
// 404页面
gogo.STATUS(http.StatusNotFound, func(ctx *gogo.HTTPContext) {
ctx.WriteHeader(http.StatusNotFound)
l, err := gogo.SQLQueryByMap("webname", "*", "dede_flink", "", "", 0, 100)
if err == nil {
ctx.WriteExecute(l,
"views/notfound.tmpl")
return
}
})
// 启动HTTP服务
gogo.Run(":8080")
}
以上所述就是小编给大家介绍的《Go 一键生成 后端 restful api》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 实战生成对抗网络(二):生成手写数字
- 实战生成对抗网络[2]:生成手写数字
- 020.Python生成器和生成器函数
- faker生成器生成虚拟数据的Python模块
- 利用代码生成工具生成基于ABP框架的代码
- 数据生成工具 ZenData 1.4 发布,内置国家、日期、时间格式,支持文章生成
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Perl语言编程
克里斯蒂安森 (Tom Christiansen) (作者)、Brian D Foy (作者)、Larry Wall (作者)、Jon Orwant (作者) / 苏金国 (译者)、吴爽 (译者) / 中国电力出版社 / 2014-9-1 / 148
从1991年第一版问世以来,《Perl语言编程》很快成为无可争议的Perl宝典,如今仍是这种高实用性语言的权威指南。Perl最初只是作为一个功能强大的文本处理工具,不过很快发展成为一种通用的编程语言,可以帮助成千上万的程序员、系统管理员,以及像你一样的技术爱好者轻松完成工作。 人们早已经翘首以待这本“大骆驼书”的更新,如今终于得偿所愿。在这一版中,三位颇有声望的Perl作者讲述了这种语言当前......一起来看看 《Perl语言编程》 这本书的介绍吧!