FormulaGo

Go License Hertz

English | 中文

简介

FormulaGo 是一个高性能的企业后台管理框架,基于 HertzEnt 构建。遵循 Clean Architecture / DDD 设计理念,开箱即用的 RBAC 权限管理系统。

前端项目地址:formulago-front

架构

biz/handler/  →  biz/logic/  →  biz/domain/  →  data/
(HTTP 层)        (业务逻辑)       (接口定义)     (数据访问)

技术栈

组件
HTTP 框架 Hertz
ORM Ent
认证 hertz-contrib/jwt
权限 Casbin
数据库 MySQL / PostgreSQL
缓存 go-cache + Redis
配置 koanf
对象存储 阿里云 OSS

快速开始

前置条件

1. 配置

编辑 configs/config.yaml 配置文件。敏感信息建议通过环境变量设置,避免提交到 git:

# 复制环境变量模板
cp secret.sh.example secret.sh

# 编辑 secret.sh 填入真实密钥
# 然后加载到当前 shell
source secret.sh

secret.sh 已加入 .gitignore,不会误提交。

2. 启动 MySQL

docker-compose up -d

3. 运行

go build -o formulago && ./formulago

4. 初始化数据库

curl http://localhost:8191/api/initDatabase

默认管理员账号:admin / formulago

内置功能

模块 功能描述
用户管理 系统用户增删改查,角色分配
角色管理 RBAC 角色 CRUD,菜单和 API 权限分配
菜单管理 分层级菜单树,按钮级权限标识
字典管理 键值对字典维护,支持多级字典明细
API 管理 API 资源注册和管理,用于权限配置
操作日志 自动记录请求/响应日志,支持查询
Token 管理 在线用户 Token 监控,强制下线
文件管理 文件上传,阿里云 OSS 适配,图片压缩
OAuth 2.0 登录 支持 Google、GitHub、企业微信认证
验证码 数字验证码,支持配置长度和尺寸

项目结构

├── api/                  # Protobuf 定义和生成模型
│   ├── model/            # 生成的 Go 结构体
│   └── admin/            # 管理员 API Protobuf IDL
├── biz/                  # 业务逻辑
│   ├── domain/           # 纯 Go 接口定义(无外部依赖)
│   ├── handler/          # HTTP 处理层(参数绑定、响应)
│   │   └── middleware/   # JWT 认证、Casbin 权限、日志
│   ├── logic/            # 业务逻辑实现
│   └── router/           # 路由注册
├── configs/              # YAML 配置文件(嵌入二进制)
├── data/                 # 数据访问层
│   ├── ent/              # Ent ORM 生成代码
│   │   └── schema/       # Ent 数据模型定义
│   ├── s3/               # 阿里云 OSS 适配器
│   └── ...               # MySQL、PostgreSQL、Redis、Casbin
└── pkg/                  # 通用工具包
    ├── captcha/          # 验证码缓存
    ├── encrypt/          # bcrypt 密码加密
    ├── img/              # 图片压缩
    ├── types/            # 常用类型工具
    └── wecom/            # 企业微信集成

开发指南

代码生成

Ent(数据模型 → CRUD):

go generate ./data/ent

Hertz(Protobuf → 处理器和路由):

hz update -I api -idl api/admin/admin.proto -model_dir api/model --unset_omitempty

hz update -I api -idl api/admin/admin.proto -model_dir api/model --unset_omitempty

新增/编辑实体步骤

下面是admin管理模块相关的步骤,其他模块的步骤类似

  1. data/ent/schema/ 创建/修改 schema
  2. 运行 ent 代码生成
  3. biz/domain/admin/ 定义领域接口
  4. biz/logic/admin/ 实现业务逻辑
  5. api/admin/admin.proto Protobuf定义API接口
  6. 运行 hz 生成处理器和路由
  7. biz/handler/admin/ 实现处理器逻辑,注意把req\resp放一起初始化,让所有返回都使用上resp

License

Apache License 2.0