这个项目是以Gin框架为基础搭建的后台管理平台,虽然很多人都认为go是用来开发高性能服务端项目的,但是也难免有要做web管理端的需求,总不能再使用别的语言来开发吧。所以整合出了GinAdmin项目,请大家多提意见指正!欢迎 star ⭐⭐
- golang > 1.8
- Gin
- BootStrap
- LayUi
- WebUpload
- Light Year Admin Using Iframe
✅权限控制
✅日志管理
✅模板页面
✅自动分页
✅Docker部署
✅静态资源打包
✅性能监控
✅API JWT
✅redis日志落盘保存
🔲登录日志
🔲Admin Api
🔲Admin Vue
🔲命令行操作
🔹演示地址
- http://122.152.196.83/admin/login 账号:admin 密码: 111111
🔹开始使用
-
git 克隆地址
git clone https://github.com/gphper/ginadmin.git -
下载依赖包
go mod download
-
配置
configs/config.ini文件[mysql] username=root password=123456 database=db_beego host=127.0.0.1 port=3306 max_open_conn=50 max_idle_conn=20 [redis] addr=localhost:6379 db=0 password="" [session] session_name=gosession_id [base] host=0.0.0.0 port=20011 fill_data=true migrate_table=true log_media=redis -
运行
go run .\cmd\ginadmin访问地址 http://localhost:端口地址/admin/login。默认账户:admin 密码:111111 -
vscode调试配置文件
launch.json
{
"version": "0.2.0",
"configurations": [
{
"name": "ginadmin",
"type": "go",
"request": "launch",
"mode": "debug",
"program": "${workspaceRoot}/cmd/ginadmin",
"trace": true,
"args":[
"--root_path=${workspaceRoot}"
],
}
}-
替换conf目录下的配置项
[mysql] username=docker password=123456 database=docker_mysql host=localmysql port=3306 max_open_conn=50 max_idle_conn=20 [session] session_name=gosession_id [base] host=0.0.0.0 port=20010 fill_data=true [redis] addr=localredis:6379 db=0 password=ginadmin
-
执行命令
docker-compose up -d -
进入到容器中
docker exec -it ginadmin-web bash -
下载扩展
go mod tidy -
运行项目
go run ./cmd/ginadmin/访问地址http://localhost:20010/admin/login -
桌面连接redis地址
地址:127.0.0.1 端口:6380 密码:ginadmin -
桌面连接mysql地址
地址:localhost 端口:3310 用户名:docker 密码:123456
🔹项目目录
|--api // Api接口控制器
|--build // 封装的公共方法
|--cmd // 命令行工具
|--configs // 配置文件
|--deployments // docker-compose 部署文件
|--internal //核心代码
|--logs // 日志存放目录
|--pkg // 公共调用部分
|--web //视图静态文件
🔹分页
- 使用
pkg/paginater/paginater.go里面的PageOperation进行分页adminDb := models.Db.Table("admin_users").Select("nickname","username").Where("uid != ?", 1) adminUserData := paginater.PageOperation(c, adminDb, 1, &adminUserList)
- 在html中使用
{{ .adminUserData.PageHtml }}
🔹日志
-
系统日志
设置路由中间件来收集系统日志和错误日志,设置
internal/router/default.go文件 -
自定义日志
使用 loggers.LogInfo()
方法记录日志github.com/gphper/ginadmin/pkg/loggers`loggers.LogInfo("admin", "this is a info message", map[string]string{ "user_info": "this is a user info", })
-
切换存储介质
在配置文件中修改
log_media参数默认file文件存储可选redis存储
🔹数据库
-
models下定义的文件均需要实现
TableName() string方法,并将实现该结构体的指针写入到GetModels方法中func GetModels() []interface{} { return []interface{}{ &AdminUsers{}, &AdminGroup{}, } }
-
model需要继承 BaseModle 并且实现 TableName 方法,如果需要初始化填充数据的话,需要实现 FillData() 方法,并将数据填充需要执行的代码写到函数体里。详情参照 AdminUsers
-
可以通过设置 ini 配置文件中的
fill_data和migrate_table分别控制程序重启时自动迁移数据表和填充数据
🔹定时任务
- 在
pkg/cron/cron.go添加定时执行任务
🔹配置文件
-
现在
configs/config.go添加配置项的 struct 类型,例如type AppConf struct { BaseConf `ini:"base"` } type BaseConf struct { Port string `ini:"port"` }
-
在
configs/config.ini添加配置信息[base] port=:8091 -
在代码中调用配置文件的信息
configs.App.BaseConf.Port
🔹模板页面
- 所有的后台模板都写到
web/views/template目录下面,并且分目录存储,调用时按照目录/模板名称的方式调用
🔹用户权限
-
菜单权限定义到
internal/menu/menu.go文件下,定义完之后在用户组管理里面编辑权限 -
casbin版集成了casbin权限管理框架,官方地址:casbin
-
框架中的常用方法定义在
pkg/casbinauth/casbin.go文件中 -
在控制器中可用从
gin.context获取登录用户信息info,_ := c.Get("userInfo")
-
template 中判断权限的函数
judgeContainPriv定义在pkg/template/default.go文件下"judgeContainPriv": func(username string, obj string, act string) bool { if username == "admin" { return true } ok, err := casbinauth.Check(username, obj, act) if !ok || err != nil { return false } return true },
-
使用 swagg 生成api文档,生成文件再docs目录下
swag init -g cmd/ginadmin/main.go -
在根目录执行
go build .\cmd\ginadmin\然后啊访问 http://localhost:20010/swagger/index.html
🔹线上部署
- 使用
go build -tags=release .\cmd\ginadmin生成二进制文件 - 打包静态资源部署
go build -tags=embed .\cmd\ginadmin
🔹性能监控
- 推荐使用 prometheus + grafana 进行性能监控,参考示例 https://github.com/gphper/ginmonitor

