Go 语言,开源服务端代码自动生成 框架 - EasyGoServer
EasyGoServer
作者:林冠宏 / 指尖下的幽灵
GitHub : https://github.com/af913337456/
联系方式 / Contact:913337456@qq.com
EasyGoServer
---- 概述
---- 脚本介绍
-------- Linux
-------- Windows
-------- Mac
---- 使用流程
---- 部分代码说明
---- 开源地址
概述
一个能够仅仅依赖你创建好的 sql 文件,就能 自动帮你生成基础服务端框架代码
的 go server 框架。包含有:
1,基础的 增删改查
2,拓展性强的API
3,客户端的数据传入 与 服务端的输出 全部依赖 struct
- 例如你的一个输入结构体
inputStruct
设置为
type inputStruct struct {
Id int64 `json:"id" nullTag:"1"` // nullTag==1 指明 id 必须要求在客户端传入 {"id":123}
Name string `json:"name" nullTag:"0"` // ==0 指明 name 在客户端输入的时候可以不必要
}
对应上例,客户端输入的 json :
{"id":666, "name":"lgh"}
- 当你在使用 select 的时候,你的 sql 如果是这样的:
select User.id , User.age from User
那么你的对应输出结构体outputStruct
应该是:
type inputStruct struct {
Id int64 `json:"id"`
Age int64 `json:"age"`
}
4,真正需要你写的代码极少,例如第三点的例子,你要写的就那么多,其中默认的 struct 会自动帮你生成
脚本介绍
根据 sql 文件,自动生成代码文件,包含有 struct.go,每张表对应生成一个包含有增删改查的基础方法文件
one_key_create_code
根据内置的 makefile 或者 .bat 编译并运行默认的 go server 程序,注意是默认的
make_server
Linux
one_key_create_code.sh
make_server.sh
Makefile
Windows
one_key_create_code.bat
make_server.bat
Mac
参照 linux 的
使用流程
1,在你的 服务器 安装 mysql 或者 mariadb
2,编写好的你的 sql 文件,可以参照我源码里面的 this.sql
3,运行步骤2编写好的 sql 文件
4,修改 sql_2_api.go 里面 main 内的 sql 文件名称
5,运行 one_key_create_code 脚本,成功后会在同级目录生成下面文件,记得刷新目录
struct.go
,里面包含注释规范- 对应你 sql 文件里面的表名称生成的函数文件,格式:
func_表名称.go
6,自己写好,main.go 或者 使用我提供的默认 LghSampleMain.go
,在里面 添加你自己的路由
router.HandleFunc("/insert",insert_luser_sample).Methods("POST")
router.HandleFunc("/select",select_luser_sample).Methods("GET")
router.HandleFunc("/update",update_luser_sample).Methods("POST")
router.HandleFunc("/delete",delete_luser_sample).Methods("POST")
7,配置好 conf.json 文件,我里面有例子
// Host 是绝对路径
// Port 是要被监听的端口
{
"Host": "127.0.0.1",
"Port": ":8884",
"FilePort":":8885",
"DbName":"database",
"DbUser":"root",
"DbPw":"123456",
"DbPort":"3306"
}
8,现在执行 make_server 脚本,观察控制台的输出,即可。
部分代码说明
核心的参数结构体
type LghRequest struct {
w http.ResponseWriter
r *http.Request
// 标记使用,当前的方法名称
funcName string
// 输入的结构体,与客户端输入的 json 成对应关系
inputStruct interface{}
// 自定义 slices 的回调,方便你做参数处理,返回 true 意味着此次操作终止,例如 update
slicesCallBack func(slices []interface{}) bool
// 根据传入的 jsonObj 生成的 slices 来回调,方法生成自定义 sql
getSqlCallBack func(slices []interface{},inputStruct interface{}) string
}
例子方法
1,演示不需要参数的形式
/** 演示不需要参数的形式 */
func update_0(w http.ResponseWriter,r *http.Request) {
request := LghRequest{
w,
r,
"update_luser",
nil, /** nil 表示没输入结构体 */
func(slices *[]interface{}) bool{
return false
},
func(slices *[]interface{},inputStruct interface{}) string {
return "update LUser set u_user_id='444' where id='1'"
}}
updateDataByStruct(request)
}
2,演示当有参数输入的时候,参数仅做判断,但是不需要组合到 sql 的情况
/** 演示当有参数输入的时候,参数仅做判断,但是不需要组合到 sql的情况 */
func update_1(w http.ResponseWriter,r *http.Request) {
type testS struct {
Id int64 `json:"id" nullTag:"1"` // nullTag==1 指明 id 必须要求在客户端传入 {"id":123}
}
request := LghRequest{
w,
r,
"update_luser",
new (testS),
func(slices []interface{}) bool{
// 在这里对 slices 做你想做的操作,增加或者删除等等
if slices[0] == -1{
return true /** 返回 true,终止插入,提示错误或者其它 */
}
slices = append(slices[:0], nil) /** 自己做完处理删除掉 */
return false
},
func(slices []interface{},inputStruct interface{}) string {
// 如果你想根据输入的 json 数据来特定生成 sql,那么就可以在这里使用 slices 来操作
return "update LUser set u_user_id='444' where id='2'"
}}
updateDataByStruct(request)
}
3,演示使用输入参数的情况
/** 演示使用输入参数的情况 */
func update_luser_sample(w http.ResponseWriter,r *http.Request) {
type testS struct {
Id int64 `json:"id" nullTag:"1"`
}
request := LghRequest{
w,
r,
"update_luser",
new (testS),
func(slices []interface{}) bool{
return false
},
func(slices []interface{},inputStruct interface{}) string {
return "update LUser set u_user_id='444' where id=?" /** 对应 id */
}}
updateDataByStruct(request)
}
开源地址
https://github.com/af913337456/EasyGoServer
Go 语言,开源服务端代码自动生成 框架 - EasyGoServer的更多相关文章
- 开源:C# 代码自动生成工具,支持站点前后台
前言 写这个项目有很长一段时间了,期间也修修改改,写到最后,自己也没咋用(研究方向变化了). 正文 具体项目开源了:https://github.com/supperlitt/WebAutoCodeO ...
- 关于,java-webservice接口,根据服务端,自动生成客户端调用时,响应时间慢
我这边遇到的问题,是在和对方进行webservice接口交互的时候,用工具,调用对方的webservice接口,对方响应很快.但是用java生成的客户端调用就会很慢才得到响应.大概有5分钟左右. 这里 ...
- C# 代码自动生成工具
开源:C# 代码自动生成工具,支持站点前后台 前言 写这个项目有很长一段时间了,期间也修修改改,写到最后,自己也没咋用(研究方向变化了). 正文 具体项目开源了:https://github.co ...
- webservice 服务端例子+客户端例子+CXF整合spring服务端测试+生成wsdl文件 +cxf客户端代码自动生成
首先到CXF官网及spring官网下载相关jar架包,这个不多说.webservice是干嘛用的也不多说. 入门例子 模拟新增一个用户,并返回新增结果,成功还是失败. 大概的目录如上,很简单. Res ...
- openssl实现双向认证教程(服务端代码+客户端代码+证书生成)
一.背景说明 1.1 面临问题 最近一份产品检测报告建议使用基于pki的认证方式,由于产品已实现https,商量之下认为其意思是使用双向认证以处理中间人形式攻击. <信息安全工程>中接触过 ...
- 根据wsdl,apache cxf的wsdl2java工具生成客户端、服务端代码
根据wsdl,apache cxf的wsdl2java工具生成客户端.服务端代码 apache cxf的wsdl2java工具的简单使用: 使用步骤如下: 一.下载apache cxf的包,如apac ...
- 代码自动生成工具MyGeneration之一(程序员必备工具)
代码自动生成工具MyGeneration之一(程序员必备工具) 转 分类: C#2008-08-06 18:12 16064人阅读 评论(12) 收藏 举报 工具数据库相关数据库stringbrows ...
- Mybatis Generator代码自动生成(实体类、dao层、映射文件)
写了一段时间增删改查有点厌烦,自己找了下网上的例子鼓捣了下自动生成. 首先得有一个配置文件: generatorConfig.xml <?xml version="1.0" ...
- Asp.net mvc 5 CRUD代码自动生成工具- vs.net 2013 Saffolding功能扩展
Asp.net mvc 5 CRUD代码自动生成工具 -Visual Studio.net2013 Saffolding功能扩展 上次做过一个<Asp.net webform scaffoldi ...
随机推荐
- 我的学习之路_第三十章_servlet
servlet:小服务程序 servlet是JavaWeb体系中的三大核心(servlet/Filter/Listener)之一,而且是最主要的那个. 作用:接受请求,处理请求,做出响应 继承体系:s ...
- 关于EF 通用增删改查的封装
1. Entity Framework是Microsoft的ORM框架,随着 Entity Framework 不断的完善强化已经到达了EF 6.0+ 还是非常的完善的,目前使用的比例相对于其他OR ...
- TCP传输协议使用
TCP传输协议,也称之为套接字连接,比较安全,三次握手!,必须确保对方计算机存在,才能连接,而且是长时间连接. 缺点是传输速度有点慢. 你用 socket 去连接 ServiceSocaket 服务器 ...
- css3-transition过渡属性
transition主要是用于一个元素的一种状态到另一种状态的一个过渡的过程,不能够主动触发,必须依赖于事件,例如hover伪类选择器. 一,transition简写 transition:要过渡的属 ...
- 关于Class.forName(className).newInstance()介绍
Class.forName(xxx.xx.xx) 返回的是一个类 首先你要明白在java里面任何class都要装载在虚拟机上才能运行.这句话就是装载类用的(和new 不一样,要分清楚). 至于什么时候 ...
- (转)SqlServer基础之(触发器)(清晰易懂)
阅读目录 一:触发器的优点 二:触发器的作用 三:触发器的分类 四:触发器的工作原理 五:创建触发器 六:管理触发器 概念: 触发器(trigger)是SQL server 提供给程序员和数据分析 ...
- HDU 6035---Colorful Tree(树形DP)
题目链接 Problem Description There is a tree with n nodes, each of which has a type of color represented ...
- listView属性随笔--不断增加中。
对于一个控件的认识总是会随着时间的推移,而变的逐渐深刻. 简单的就 android:layout_height:属性来说给的数值不同就会有不同的效果,有些时候你根本想不到是跟这个属性的设置有关. 有时 ...
- 3624: [Apio2008]免费道路
Description Input Output Sample Input 5 7 2 1 3 0 4 5 1 3 2 0 5 3 1 4 3 0 1 2 1 4 2 1 Sample Output ...
- word2vec原理(二) 基于Hierarchical Softmax的模型
word2vec原理(一) CBOW与Skip-Gram模型基础 word2vec原理(二) 基于Hierarchical Softmax的模型 word2vec原理(三) 基于Negative Sa ...