Go 一键生成 后端 restful api

栏目: Go · 发布时间: 6年前

一键生成 后端 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》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

100个可操作的网络赚钱方法

100个可操作的网络赚钱方法

陶秋丰 / 云南科技 / 2009-12 / 29.80元

《100个可操作的网络赚钱方法》专为有志于网上创业的读者量身打造,作者是“实战型”的网赚高手,在17岁时就通过互联网创业“年人10万”,如今结合自身的亲身实战经验,与大家分享可以实实在在盈利的100个网络赚钱方法和技巧。内容包括:网站创建与推广、竞价广告、联盟赚钱、网站SEO优化、域名投资、广告投放盈利、威客、博客、淘客赚钱等多个方面。 本手册中作者结合自身的网络赚钱经历,通过具体的、可操作......一起来看看 《100个可操作的网络赚钱方法》 这本书的介绍吧!

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具