快速开始¶
GoAdmin通过各种适配器使得你在各个web框架中使用都十分的方便。目前支持的web框架有:
gin / beego / fasthttp / buffalo / echo / gorilla/mux / iris / chi / gf
您可以选择拿手的或者业务项目正在用的框架开始,如果上述没有你喜欢的框架,欢迎给我们提issue!
下面演示一下怎么快速搭建和启动项目。
初始化¶
首先新建一个项目文件夹,然后进入文件夹中使用最新版命令行工具 adm 执行:
$ adm init -l cn
或者使用以下命令,可以打开一个web界面安装:
$ adm init web -l cn
初始化完成后,在你的项目文件夹下会生成整个项目的骨架。其中有一个main.go
文件,内容如下:
package main
import (
"io/ioutil"
"log"
"os"
"os/signal"
_ "github.com/GoAdminGroup/go-admin/adapter/gin" // 引入适配器,必须引入,如若不引入,则需要自己定义
_ "github.com/GoAdminGroup/themes/adminlte" // 引入主题,必须引入,不然报错
_ "github.com/GoAdminGroup/go-admin/modules/db/drivers/mysql" // 引入对应数据库引擎
"github.com/GoAdminGroup/go-admin/engine"
"github.com/GoAdminGroup/go-admin/template"
"github.com/GoAdminGroup/go-admin/template/chartjs"
"github.com/gin-gonic/gin"
"xxx/pages"
"xxx/tables"
)
func main() {
startServer()
}
func startServer() {
gin.SetMode(gin.ReleaseMode)
gin.DefaultWriter = ioutil.Discard
r := gin.Default()
template.AddComp(chartjs.NewChart())
// 实例化一个GoAdmin引擎对象
eng := engine.Default()
// 增加配置与插件,使用Use方法挂载到Web框架中
if err := eng.AddConfigFromJSON("./config.json").
// 这里引入你需要管理的业务表配置
// 后面会介绍如何使用命令行根据你自己的业务表生成Generators
AddGenerators(tables.Generators).
Use(r); err != nil {
panic(err)
}
r.Static("/uploads", "./uploads")
eng.HTML("GET", "/admin", pages.GetDashBoard)
eng.HTMLFile("GET", "/admin/hello", "./html/hello.tmpl", map[string]interface{}{
"msg": "Hello world",
})
_ = r.Run(":9033")
quit := make(chan os.Signal)
signal.Notify(quit, os.Interrupt)
<-quit
log.Print("closing database connection")
eng.MysqlConnection().Close()
}
请留意以上代码与注释,对应的步骤都加上了注释,十分好理解:
- 匿名引入适配器,主题与数据库驱动(必须)
- 载入设置好的全局配置项:
eng.AddConfig
- 挂载到Web框架中:
eng.Use
接着根据提示依次执行: (以下为mac/linux用户执行命令,windows用户需根据提示执行)
$ make init module=xxx
$ GORPOXY=https://goproxy.io make install
$ make serve
运行代码,访问:http://localhost:9033/admin/login
默认登录账号:admin
默认登录密码:admin
注意:golang版本高于1.11强烈建议开启GO111MODULE=on
,如果运行下载依赖有问题,这里提供了依赖包下载:
添加业务表管理¶
详见:
前端模板文件分离¶
如果对前端功能需要较多自定义,可使用模板文件分离的形式。
假设已经使用adm init
初始化一个模板后,那么需要进行以下几步更改:
- 修改main.go文件,修改导入主题包为分离主题包
- 下载模板文件夹public到本地
- 修改config.json文件:
- 改动主题 theme 配置项:adminlte 改为 adminlte_sep,sword 改为 sword_sep
- 增加 asset_root_path 配置项,为模板文件夹(public)的地址,建议用绝对路径,末尾需要带上斜杆
- 重新启动,并在网站右上角进去设置页更改主题
这时修改一下模板文件夹下文件public/pages/header.tmpl
试试吧!
main.go
package main
import (
...
_ "github.com/GoAdminGroup/themes/adminlte/separation"
...
)
func main() {
startServer()
}
func startServer() {
...
}
config.json
{
...
"theme": "sword_sep",
...
"asset_root_path": "./public/"
}
全局配置项说明¶
https://github.com/GoAdminGroup/go-admin/blob/master/modules/config/config.go
注意:配置一旦初始化生成后,后续修改请在网站右上角中进入配置中心修改!
注意:配置一旦初始化生成后,后续修改请在网站右上角中进入配置中心修改!
注意:配置一旦初始化生成后,后续修改请在网站右上角中进入配置中心修改!
package config
import (
"html/template"
)
type Database struct {
Host string // 地址
Port string // 端口
User string // 用户名
Pwd string // 密码
Name string // 数据库名
MaxIdleCon int // 最大闲置连接数
MaxOpenCon int // 最大打开连接数
Driver string // 驱动名
File string // 文件名
DSN string // DSN语句:如果设置了DSN语句,则优先使用DSN进行连接
Params map[string]string // DSN的额外参数
}
// 数据库配置
// 为一个map,其中key为数据库连接的名字,value为对应的数据配置
// 注意:key为default的数据库是默认数据库,也是框架所用的数据库,而你可以
// 配置多个数据库,提供给你的业务表使用,实现对不同数据库的管理。
type DatabaseList map[string]Database
// 存储目录:存储头像等上传文件
type Store struct {
Path string // 存储路径
Prefix string // url访问前缀
}
type Config struct {
// 数据库配置
Databases DatabaseList `json:"database"`
// 登录域名
Domain string `json:"domain"`
// 网站语言
Language string `json:"language"`
// 全局的管理前缀
UrlPrefix string `json:"prefix"`
// 主题名
Theme string `json:"theme"`
// 上传文件存储的位置
Store Store `json:"store"`
// 网站的标题
Title string `json:"title"`
// 侧边栏上的Logo
Logo template.HTML `json:"logo"`
// 侧边栏上的Logo缩小版
MiniLogo template.HTML `json:"mini_logo"`
// 登录后跳转的路由
IndexUrl string `json:"index"`
// 自定义登录路由地址
LoginUrl string `json:"login_url",yaml:"login_url",ini:"login_url"`
// 是否开始debug模式
Debug bool `json:"debug"`
// Info日志路径
InfoLogPath string `json:"info_log"`
// Error log日志路径
ErrorLogPath string `json:"error_log"`
// Access log日志路径
AccessLogPath string `json:"access_log"`
// 是否开始数据库Sql操作日志
SqlLog bool `json:"sql_log"`
// 是否关闭access日志
AccessLogOff bool `json:"access_log_off"`
// 是否关闭info日志
InfoLogOff bool `json:"info_log_off"`
// 是否关闭error日志
ErrorLogOff bool `json:"error_log_off"`
// 日志配置
Logger Logger `json:"logger",yaml:"logger",ini:"logger"`
// 网站颜色主题
ColorScheme string `json:"color_scheme"`
// Session的有效时间,单位为秒
SessionLifeTime int `json:"session_life_time"`
// Cdn链接,为全局js/css配置cdn链接
AssetUrl string `json:"asset_url"`
// 文件上传引擎
FileUploadEngine FileUploadEngine `json:"file_upload_engine"`
// 自定义头部js/css
CustomHeadHtml template.HTML `json:"custom_head_html"`
// 自定义尾部js/css
CustomFootHtml template.HTML `json:"custom_foot_html"`
// 登录页面标题
LoginTitle string `json:"login_title"`
// 登录页面logo
LoginLogo template.HTML `json:"login_logo"`
// 自定义认证用户的数据表
AuthUserTable string `json:"auth_user_table",yaml:"auth_user_table",ini:"auth_user_table"`
// 额外
Extra ExtraInfo `json:"extra",yaml:"extra",ini:"extra"`
// 页面动画
Animation PageAnimation `json:"animation",yaml:"animation",ini:"animation"`
// 是否不限制不同IP登录,默认限制
NoLimitLoginIP bool `json:"no_limit_login_ip",yaml:"no_limit_login_ip",ini:"no_limit_login_ip"`
// 网站开关
SiteOff bool `json:"site_off",yaml:"site_off",ini:"site_off"`
// 是否隐藏配置中心入口,默认显示
HideConfigCenterEntrance bool `json:"hide_config_center_entrance",yaml:"hide_config_center_entrance",ini:"hide_config_center_entrance"`
// 是否隐藏应用信息入口,默认显示
HideAppInfoEntrance bool `json:"hide_app_info_entrance",yaml:"hide_app_info_entrance",ini:"hide_app_info_entrance"`
// 隐藏模块列表入口,默认显示
HidePluginEntrance bool `json:"hide_plugin_entrance,omitempty" yaml:"hide_plugin_entrance,omitempty" ini:"hide_plugin_entrance,omitempty"`
// 自定义404页面
Custom404HTML template.HTML `json:"custom_404_html,omitempty",yaml:"custom_404_html",ini:"custom_404_html"`
// 自定义403页面
Custom403HTML template.HTML `json:"custom_403_html,omitempty",yaml:"custom_403_html",ini:"custom_403_html"`
// 自定义500页面
Custom500HTML template.HTML `json:"custom_500_html,omitempty",yaml:"custom_500_html",ini:"custom_500_html"`
// 配置更新处理函数
UpdateProcessFn UpdateConfigProcessFn `json:"-",yaml:"-",ini:"-"`
// 是否开放admin的json apis,默认关闭
OpenAdminApi bool `json:"open_admin_api",yaml:"open_admin_api",ini:"open_admin_api"`
// 隐藏访客用户设置菜单
HideVisitorUserCenterEntrance bool `json:"hide_visitor_user_center_entrance",yaml:"hide_visitor_user_center_entrance",ini:"hide_visitor_user_center_entrance"`
// 需要排除的主题模块
ExcludeThemeComponents []string `json:"exclude_theme_components,omitempty" yaml:"exclude_theme_components,omitempty" ini:"exclude_theme_components,omitempty"`
// 引导文件路径
BootstrapFilePath string `json:"bootstrap_file_path,omitempty" yaml:"bootstrap_file_path,omitempty" ini:"bootstrap_file_path,omitempty"`
// go mod文件路径
GoModFilePath string `json:"go_mod_file_path,omitempty" yaml:"go_mod_file_path,omitempty" ini:"go_mod_file_path,omitempty"`
}
日志设置:
type Logger struct {
// 编码设置
Encoder EncoderCfg `json:"encoder",yaml:"encoder",ini:"encoder"`
// 分割设置
Rotate RotateCfg `json:"rotate",yaml:"rotate",ini:"rotate"`
// 日志级别
Level int8 `json:"level",yaml:"level",ini:"level"`
}
// 日志输出内容编码设置
type EncoderCfg struct {
// 时间键内容,默认为 ts
TimeKey string `json:"time_key",yaml:"time_key",ini:"time_key"`
// 级别键内容,默认为 level
LevelKey string `json:"level_key",yaml:"level_key",ini:"level_key"`
// 名字键内容,默认为 logger
NameKey string `json:"name_key",yaml:"name_key",ini:"name_key"`
// 调用者键内容,默认为 caller
CallerKey string `json:"caller_key",yaml:"caller_key",ini:"caller_key"`
// 消息键内容,默认为 msg
MessageKey string `json:"message_key",yaml:"message_key",ini:"message_key"`
// 栈键内容,默认为 stacktrace
StacktraceKey string `json:"stacktrace_key",yaml:"stacktrace_key",ini:"stacktrace_key"`
// 级别编码器,默认为 大写带颜色
Level string `json:"level",yaml:"level",ini:"level"`
// 时间编码器,默认为 ISO8601
Time string `json:"time",yaml:"time",ini:"time"`
// 间隔时间编码器,默认为 秒
Duration string `json:"duration",yaml:"duration",ini:"duration"`
// 调用者编码器,默认为 简短路径
Caller string `json:"caller",yaml:"caller",ini:"caller"`
// 输出格式,默认console
Encoding string `json:"encoding",yaml:"encoding",ini:"encoding"`
}
// 日志分割设置
type RotateCfg struct {
// 文件最大大小,单位为m,默认为 10m
MaxSize int `json:"max_size",yaml:"max_size",ini:"max_size"`
// 最多文件数,默认为 5个
MaxBackups int `json:"max_backups",yaml:"max_backups",ini:"max_backups"`
// 存储最长时间,单位为天,默认为 30天
MaxAge int `json:"max_age",yaml:"max_age",ini:"max_age"`
// 是否压缩,默认为 不开启
Compress bool `json:"compress",yaml:"compress",ini:"compress"`
}