项目地址:https://github.com/Benny66/ginServer 项目框架结构
项目工程主要代码文件夹目录,包括dao数据层、model模型层、service逻辑层;
- 数据层是对数据操作的封装操作;
- 模型层是对数据库表模型进行定义;
- 逻辑层是项目核心业务逻辑的处理层;
本项目框架各模块之间的调用使用,大部分采用单例模式中的饿汉模式,就是加载的时候全局初始化(缺点是启动占内存,慢),不了解的可查看同目录下
dao【数据层】是基于gorm对数据进行增删查改的模块
- Create和update 对数据的创建和修改操作均需要开启事务,在逻辑层进行控制开启、回滚和提交。
- 常见封装的方法包括增删查改、分页查询(Paginate)、查询全部(FindAll)、按条件查询(WhereQuery)、关联查询(Joins)、预加载(Preloads)等等方法
func (dao *userDao) Create(tx *gorm.DB, data *model.User) (rowsAffected int64, err error) {
db := tx.Create(data)
if err = db.Error; db.Error != nil {
return
}
rowsAffected = db.RowsAffected
return
}
func (dao *userDao) WhereQuery(query interface{}, args ...interface{}) *userDao {
return &userDao{
dao.gm.Where(query, args...),
}
}
func (dao *userDao) Joins(query string, args ...interface{}) *userDao {
return &userDao{
dao.gm.Joins(query, args),
}
}
model【模型层】就是对数据库表名和表内字段进行模型定义的模块。
- ModelTime定义自动转换存储和查询时间格式
- 可定义模型对应的表名称和表字段
type User struct {
ID uint `gorm:"primaryKey;column:id" json:"id"`
UserName string `gorm:"column:username;unique;not null" json:"username"`
Password string `gorm:"column:password;not null" json:"password"`
CreatedAt ModelTime `gorm:"column:created_at" json:"created_at"`
UpdatedAt ModelTime `gorm:"column:updated_at" json:"updated_at"`
}
service【逻辑层】是主要的代码层,开发人员基本上在这个模块上进行开发和修复bug,实现各自项目的逻辑,是最核心的内容
- api模块是对接路由的方法入口,基本上一个业务模块对应一个文件,例如登录模块的各接口可以命名为user.go
- define模块用于定义数据结构类型的目录,不同的业务类型和逻辑,需要定义不同的请求参数和返回参数结构,例如定义type UserLoginApiReq struct来接收登录接口的参数类型
- service模块,顾名思义就是业务逻辑服务的处理模块,其中包括对请求数据参数的校验、业务逻辑处理数据,调用数据层进行保存数据库
- router.go对接路由,统一定义
系统的配置模块,config.go,包括服务信息、数据库信息、日志配置信息、ws配置信息等等
数据库文件夹模块,目前使用的是轻量级的sqlite数据库,后续兼容多个数据库
数据迁移文件模块,项目初始化或升级的时候可进行数据库的数据库迁移脚本命令;
需要在根目录添加install.lock才可进行数据库迁移执行
项目的公共模块,包括:image、html、css、js等文件
启动web服务时,初始化gin的路由模块,启动服务
runtime模块,保存日志logs、缓存cache等文件
项目框架需要的工具包,包括:自我封装的库以及调用第三方封装的库