Go 一键生成 后端 restful api

一键生成 后端 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")
}

原文地址:https://blog.51cto.com/hequan/2355891

时间: 2024-10-16 01:18:58

Go 一键生成 后端 restful api的相关文章

借鉴一个比较标准的后端RESTful API

我们制定的 API 规范,使用了微服务架构所以做了一些改进,我们更偏向使用 http code 标识,不然需要自己处理成功或失败的逻辑,在 200 内再包一层显得啰嗦:并且微服务系列都不支持,Feign,监控等都需要自己改造. 当逻辑错误时,返回 http code 400,body 体内是具体的错误原因,也可以加上自定义的状态码,解决了 http code 不能满足业务状态的需求 ### 接口命名规范 **前端对接时如果发现后端提供的接口不符合规范有权拒接(包括后端对接爬虫),如接入了不符合规

6款超好用的短链接在线批量生成与接口api(新浪t.cn、腾讯url.cn)

短链接已经广泛应用于各种场景,电商,微信,短信等等.那么今天给大家推荐6款t.cn.url.cn的短链接短网址在线生成工具,都是我从市面数十款短链接短网址生成工具里面挑选的最为简便,最为稳定的短链接短网址生成工具.废话不多! 1,青梅短网址 网站链接:http://qingmeidwz.cn 青梅短网址是发展的比较成熟的一款在线短网址短链接生成工具,一直是本着“简 单,高效,自由,稳定”的理念.不管是同行业还是用户的口中都有着非常好的口碑. 青梅短网址最大的优点就和他们所倡导的理念一样:“简单,

快速创建Flask Restful API项目

前言 Python必学的两大web框架之一Flask,俗称微框架.它只需要一个文件,几行代码就可以完成一个简单的http请求服务. 但是我们需要用flask来提供中型甚至大型web restful api服务的时候就需要我们来规划项目结构. Django 框架有自身的生成项目结构的命令和生成app的命令,但是Flask没有. 这篇文章主要介绍使用工具帮助我们进行一些Flask rest api项目初始化的工作 cookiecutter-flask-restful 介绍 cookiecutter-

Android使用Bmob移动后端云Restful API需要注意的问题

如果你自己想做一个客户端玩玩,但是又不想去搭建后台服务器,显然Bmob移动后端云是你的最佳选择.官方地址见bmob,文档地址见http://www.bmob.cn/docs.他提供了Android的sdk,同样也提供了Restful Api,但是个人建议Restful Api还是不适合直接在客户端使用,毕竟会暴露一下一些key的信息,但是本篇文章就是在android中使用它的restful api,原因嘛很简单,我想网络层自己控制,不想用它提供的android sdk,对于安全方面,同样给出了这

Python Flask高级编程之RESTFul API前后端分离精讲 (网盘免费分享)

Python Flask高级编程之RESTFul API前后端分离精讲 (免费分享)  点击链接或搜索QQ号直接加群获取其它资料: 链接:https://pan.baidu.com/s/12eKrJKN-MzscalsJKRoL5w 提取码:88hj 免费分享,如若链接失效请加群 其它资源在群里,私聊管理员即可免费领取:群——517432778,点击加群,或扫描二维码 免费课程资料领取目录:  Python Flask构建微信小程序订餐系统 Python分布式爬虫必学框架Scrapy打造搜索引擎

Flask之RESTFul API前后端分离

Flask之RESTFul API前后端分离 一:虚拟环境搭建的两种方式 1 pipenv的使用 pip install --user pipenv安装pipenv在用户目录下 py -m site --user-site通过此命令找到用户基础目录,结果为C:\Users\u14e\AppData\Roaming\Python\Python35\site-packages 将用户基础目录结尾的site-packages换成Scripts,即C:\Users\u14e\AppData\Roamin

Meteor 前端 RESTful API 通过后端 API 下载文件

Meteor 下载文件 问题场景 后端 HTTP 服务器提供一个下载接口,但是需要前端 Meteor 能够给浏览器用户开一个URL来下载这个文件. 举例:在线的Meteor Logo文件就好比后端提供的 RESTful API,然后我们给浏览器客户暴露一个 URL 来下载 Meteor 依赖 安装所有依赖: meteor add http meteor add cfs:http-methods meteor add froatsnook:request 说明: * cfs:http-method

前后端分离与 restful api

为什么要前后端分离(优点): PC,APP,PAD 多端适应 单页面应用(Single Page Application)SPA开发模式开始流行 前后端开发职责不清 开发效率问题,前后端互相等待 前端一直配合着后端,能力受限 后台开发语言和模板高度耦合,导致开发语言依赖严重 前后端分离缺点: 前后端学习门槛都增加 数据依赖导致文档重要性增加,文档很重要在前后端分离模式中 搜索引擎优化SEO(Search Engine Optimization)的难度增大 后端开发模式迁移成本增加 restful

Spring Boot中使用Swagger2生成RESTful API文档(转)

效果如下图所示: 添加Swagger2依赖 在pom.xml中加入Swagger2的依赖 <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <versi