V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
pliex
V2EX  ›  程序员

gin-vue-admin v2.1.0 版本更新 内容更多更快捷

  •  1
     
  •   pliex · 2020-07-10 16:51:14 +08:00 · 3063 次点击
    这是一个创建于 1646 天前的主题,其中的信息可能已经有所发展或是发生改变。

    没错,又是我,来占用大家一点版块,介绍一下团队憋了一个月憋出来的一个 Gin-Vue-Admin 的新版本

    大家可以进行项目体验,喜欢可以 star,不喜欢可以 issue 提出改进意见~

    您的鼓励是我们前进的动力 (为什么这句话自动变黄了?)

    Gin-Vue-Admin

    Gin-Vue-Admin 是一款自动化全站后台管理系统脚手架

    Gin-Vue-Admin

    v2.1.0 版本新内容

    1 增加了数据库对应类型字典

    2 增加了操作行为记录功能

    3 增加了从数据库一键生成 curd 以及前端代码功能

    4 增加了自动化代码批量删除功能

    5 分离了 windows 环境和其他环境的启动代码

    6 清理了初始化 sql 脏数据

    7 增加了 sql 更新补丁 跟随版本可以进行部分功能更新

    8 限制了角色 id 输入 前端不再允许输入除数字以外内容

    GIN-VUE-ADMIN 是一个基于 vue 和 gin 开发的全栈前后端分离的后台管理系统,拥有 jwt 鉴权,动态路由,动态菜单,casbin 鉴权,表单生成器,代码生成器等功能,新版本增加了从数据库表一键创建前后端 curd 代码功能,方便大家从老系统迁移,大大减少了开发工作量,真正做到 5 分钟一套基础业务,让大家把更多时间专注在复杂业务开发上。

    项目地址

    演示 demo: http://demo.gin-vue-admin.com (如提示备案中请使用备用站点)

    备用站点: http://qmplus.henrongyi.top ( 2020/07/11 前请使用备用站点)

    (测试用户名:admin,测试密码:123456)

    项目 github: https://github.com/flipped-aurora/gin-vue-admin

    技术选型

    • 前端:用基于vueElement-UI构建基础页面。
    • 后端:用Gin快速搭建基础 restful 风格 API,Gin是一个 go 语言编写的 Web 框架。
    • 数据库:采用MySql(5.6.44)版本,使用gorm实现对数据库的基本操作,已添加对 sqlite 数据库的支持。
    • 缓存:使用Redis实现记录当前活跃用户的jwt令牌并实现多点登录限制。
    • API 文档:使用Swagger构建自动化文档。
    • 配置文件:使用fsnotifyviper实现yaml格式的配置文件。
    • 日志:使用go-logging实现日志记录。

    主要功能

    • 权限管理:基于jwtcasbin实现的权限管理
    • 文件上传下载:实现基于七牛云的文件上传操作(为了方便大家测试,我公开了自己的七牛测试号的各种重要 token,恳请大家不要乱传东西)
    • 分页封装:前端使用 mixins 封装分页,分页方法调用 mixins 即可
    • 用户管理:系统管理员分配用户角色和角色权限。
    • 角色管理:创建权限控制的主要对象,可以给角色分配不同 api 权限和菜单权限。
    • 菜单管理:实现用户动态菜单配置,实现不同角色不同菜单。
    • api 管理:不同用户可调用的 api 接口的权限不同。
    • 配置管理:配置文件可前台修改(测试环境不开放此功能)。
    • 字典管理:配置字典类型相关内容
    • 操作记录:记录用户的操作行为
    • 富文本编辑器:MarkDown 编辑器功能嵌入。
    • 条件搜索:增加条件搜索示例。
    • restful 示例:可以参考用户管理模块中的示例 API 。
    前端文件参考: src\view\superAdmin\api\api.vue 
    后台文件参考: model\dnModel\api.go 
    
    • 多点登录限制:需要在config.yaml中把system中的useMultipoint修改为 true(需要自行配置 Redis 和 Config 中的 Redis 参数,测试阶段,有 bug 请及时反馈)。
    • 分片长传:提供文件分片上传和大文件分片上传功能示例。
    • 表单生成器:表单生成器借助 @form-generator
    • 代码生成器:后台基础逻辑以及简单 curd 的代码生成器。

    前端环境

    1. 前往https://nodejs.org/zh-cn/下载当前版本 node
    2. 命令行运行 node -v npm -v 若控制台输出版本号则前端环境搭建成功
    3. 开发工具推荐 vscodehttps://code.visualstudio.com/

    后台环境

    1. 前往https://golang.org/dl/下载 golang 安装 版本号需>=1.12
    2. 命令行运行 go 若控制台输出各类提示命令 则安装成功 输入 go version 确认版本大于 1.12
    3. 开发工具推荐 golandhttps://www.jetbrains.com/go/

    注意事项

    • node 版本 > v8.6.0
    • golang 版本 >= v1.11
    • IDE 推荐:Goland
    • 各位在 clone 项目以后,把 db 文件导入自己创建的库后,最好前往七牛云申请自己的空间地址。
    • 替换掉项目中的七牛云公钥,私钥,仓名和默认 url 地址,以免发生测试文件数据错乱

    项目目录(2.0)

        ├─server  	     (后端文件夹)
        │  ├─api            ( API )
        │  ├─config         (配置包)
        │  ├─core  	        (內核)
        │  ├─db             (数据库脚本)
        │  ├─docs  	        ( swagger 文档目录)
        │  ├─global         (全局对象)
        │  ├─initialiaze    (初始化)
        │  ├─middleware     (中间件)
        │  ├─model          (结构体层)
        │  ├─resource       (资源)
        │  ├─router         (路由)
        │  ├─service         (服务)
        │  └─utils	        (公共功能)
        └─web            (前端文件)
            ├─public        (发布模板)
            └─src           (源码包)
                ├─api       (向后台发送 ajax 的封装层)
                ├─assets	(静态文件)
                ├─components (组件)
                ├─router	(前端路由)
                ├─store     ( vuex 状态管理仓)
                ├─style     (通用样式文件)
                ├─utils     (前端工具库)
                └─view      (前端页面)
    
    

    项目架构

    系统架构图

    系统架构图

    前端详细设计图 (提供者:baobeisuper

    前端详细设计图

    推荐的开发模式

    1. 运行项目,进入系统工具->代码生成器
    2. 设计基础结构体模型,点击生成代码包 获取前后端基础代码
    3. 前端代码添加进入 api 并自行重命名,后端代码放入适合自己开发路径中 并注册结构体到数据库,注册路由到 inirRouter (开发模式下,请自行注释掉自动生成代码中的鉴权中间件 .Use(middleware.JWTAuth()).Use(middleware.CasbinHandler()) )方便开发
    4. 前端创建 vue 文件,并到超级管理员->菜单管理->将对应路径添加进行菜单,进入角色管理,将刚配置的菜单添加进入,重启前端项目,开始绘制页面,书写交互。
    5. 接口调通以后,到超级管理员->api 管理中添加已经调通的路由,进入角色管理,将调通的路由配置进入角色权限。
    6. 简单几步过后,一个包含鉴权,动态菜单的前后端全栈功能就搞定了。

    项目配套视频教程

    gin-vue-admin: https://space.bilibili.com/322210472/channel/detail?cid=126419

    vue: https://space.bilibili.com/322210472/channel/detail?cid=108885

    golang: https://space.bilibili.com/322210472/channel/detail?cid=108884

    gin: https://space.bilibili.com/322210472/channel/detail?cid=126418

    7 条回复    2020-07-11 19:39:20 +08:00
    cai88112
        1
    cai88112  
       2020-07-10 18:28:29 +08:00
    支持支持,golang 新手,学习了不少
    shaopu
        2
    shaopu  
       2020-07-10 21:37:05 +08:00 via iPhone
    支持支持
    Youngda
        3
    Youngda  
       2020-07-11 12:08:22 +08:00
    主持一下
    pliex
        4
    pliex  
    OP
       2020-07-11 15:25:19 +08:00
    @cai88112 感谢感谢 没来得及回复 抱歉
    pliex
        5
    pliex  
    OP
       2020-07-11 15:25:29 +08:00
    @shaopu 感谢 没来得及回复 抱歉
    pliex
        6
    pliex  
    OP
       2020-07-11 15:25:40 +08:00
    @Youngda 感谢支持
    FlexGap
        7
    FlexGap  
       2020-07-11 19:39:20 +08:00
    支持,最近正好在学习 GOLANG,可以有成熟的开源项目真是太棒了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2674 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 03:31 · PVG 11:31 · LAX 19:31 · JFK 22:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.