项目地址:
https://github.com/piexlmax/gin-vue-admin
更新代码后如果遇到前端报错请执行 npm i 前端开发会不定期增加新的依赖 请注意更新
2019 年 12 月 12 日 17:15 第一次重构完成 主要更新后台数据库结构 引入 casbin 进行鉴权 后台代码结构整理 前端页面结构变更
注意!!!
在此时间之前拉取项目的朋友,pull 代码后必须重新导入数据库数据,之前数据库结构不可使用
本模板使用前端 ui 框架为 element-ui https://element.eleme.cn/#/zh-CN 前端组件可查看 elementUi 文档使用
本项目主要是小弟在接各种私活的时候发现频繁得书写 CURD 、权限管理、用户管理、列表、分页、上传下载、日志包封装、文档自动化等等功能
为了方方便各位个人开发者快速搭建项目基础模型,于是开发本模板,也为了以后自己可以省下一些初期开发的功夫
本身是前端出身,所以对于后端的项目目录或者架构可能偏向前端思维,如果有什么地方需要改动感谢大家 iss
强烈希望在各位的帮助下,此项目可以用于企业级项目的开发
各位在 clone 项目以后,把 db 文件导入自己创建的库后,最好前往七牛云申请自己的空间地址,
替换掉项目中的七牛云公钥,私钥,仓名和默认 url 地址,以免发生测试文件数据错乱
开源不易,请勿随意攻击,建议按照视频教学,本地搭建环境。
http://qmplus.henrongyi.top/
登陆以后为最高权限,动 api 权限或者菜单权限均有可能导致数据错乱,系统无法使用。请自己创建账号并设置自己角色后进行测试。
为防止恶意操作 会定期恢复数据库 如发现系统无法使用 请联系开发者
目前验证码功能测试环境由于 nginx 问题导致图片 404 暂时无法完美体验 请在本地搭建环境体验此功能
腾讯视频: https://v.qq.com/x/page/e3008xjxqtu.html (等待最新视频录制)
腾讯视频: https://v.qq.com/x/page/c3008y2ukba.html (等待最新视频录制)
1.后端采用 golang 框架 gin,快速搭建基础 restful 风格 API
2.前端项目采用 VUE 框架,构建基础页面
3.数据库采用 Mysql(5.6.44)版本不同可能会导致 SQL 导入失败
4.使用 redis 实现记录当前活跃用户的 jwt 令牌并实现多点登录限制
5.使用 swagger 构建自动化文档
6.使用 fsnotify 和 viper 实现 json 格式配置文件
7.使用 logrus 实现日志记录
8.使用 gorm 实现对数据库的基本操作
golang 项目存放于 QMPlusServer 文件夹下,
QMPlusServer 内部 static/config 存放 mysql 相关配置。可以根据自己的 mysql 数据库名 用户名 密码修改对应配置
vue 项目存放于 QMPlusVuePage 文件夹下
开源不易,感谢各位支持,错误指出即刻改正,改写纠错,感谢 star 支持
1.基本用户注册登录 √
2.用户等基础数据 CURD √
3.调用 des 实现数据加密 √
4.实现基于 jwt 的权限管理 √
5.实现基于七牛云的文件上传操作(需提前注册七牛云账号) √(为了方便大家测试,我公开了自己的七牛测试号的各种重要 token,恳请大家不要乱传东西)
6.等装了分页方法,实现分页接口并且复制粘贴就可使用分页 √
7.前端分页 mixin 封装 分页方法调用 mixins 即可 √
8.图片上传前端下载功能 √ <后端下载功能开发中>
9.富文本编辑器,MarkDown 编辑器功能嵌入 √
10.增加条件搜索示例 前端文件参考 src\view\superAdmin\api\api.vue 后台文件参考 model\dnModel\api.go √
11.增加了多点登录限制 体验需要再 static\config 中 把 system 中的 useMultipoint 修改为 true(需要自行配置 redis 和 config 中的 redis 参数)(测试阶段,有 bug 请及时反馈)√
12.增加了配置文件管理功能 √
13.大文件分片上传功能示例 √
14.日志工具封装 √
15.数据库详细日志功能启用 √
16...看项目进度想到什么做什么,主要目的是方便各位快速接私活,完成项目基础功能~~~~~~~~
17.各位开发者可以在 issues 提出自己工作中遇到的重复性大或者实现复杂的需求,我尽可能提供示例代码。
1.导入,导出 Excel
2.Echart 图表支持
3.object 模式树
4.工作流,任务交接功能开发
5.结构体前端直接录入生成对应结构体及自动建表
6.单独前端使用模式以及数据模拟
7.前端定制化生成 form,table 代码以及对应的后端结构体
1.golang api server 基于 go.mod 如果 golang 版本低于 1.11 请自行升级 golang 版本
2.支持 go.mod 的 golang 版本在运行 go list 和 编译之前都会自动下载所需要的依赖包
3.go server 建议使用 goland 运行 减少出错可能性
4.前端项目 node 建议高于 V8.6.0
5.到前端项目目录下运行 npm i 安装所需依赖
6.依赖安装完成直接运行 npm run serve 即可启动项目
7.如果要使用 swagger 自动化文档 首先需要安装 swagger
go get -u github.com/swaggo/swag/cmd/swag
由于国内没法安装到 X 包下面的东西 如果可以翻墙 上面的命令就可以让你安心使用 swagger 了 如果没有翻墙的办法那就先装一下 gopm
go get -v -u github.com/gpmgo/gopm
此时你就可以使用 gopm 了 这时候执行
gopm get -g -v github.com/swaggo/swag/cmd/swag
等待安装完成以后 到我们 GOPATH 下面的 /src/github.com/swaggo/swag/cmd/swag 路径 执行
go install
安装完成过后在项目目录下运行
swag init
项目文件夹下面会有 doc 文件夹出现 这时候登录 localhost:8888/swagger/index.html 就可以看到 swagger 文档啦
https://blog.henrongyi.top ,内有前端框架教学视频,GOLANG 基础入门视频正在筹备中。
如果觉得项目对您有所帮助可以添加我的个人微信:shouzi_1994,欢迎您提出宝贵的需求。
感谢 @chenlinzhong提供 docker 镜像
#启动容器
docker run -itd --net=host --name=go_container shareclz/go_node /bin/bash;
#进入容器
docker exec -it go_container /bin/bash;
git clone https://github.com/piexlmax/gin-vue-admin.git /data1/www/htdocs/go/admin;
#启动前端
cd /data1/www/htdocs/go/admin/QMPlusVuePage;
cnpm i ;
npm run serve;
#修改数据库配置
vi /data1/www/htdocs/go/admin/QMPlusServer/static/dbconfig/config.json;
#启动后端
cd /data1/www/htdocs/go/admin/QMPlusServer;
go run main.go;
正在研发前端独立版本分支...可以不依赖 go 服务进行使用的后台模板
感谢 krank666 协同开发
|2020/01/07| 角色增加数据资源功能 增加数据资源关联返回 演示环境代码已同步 开启了多点登录拦截 可能会被其他人挤掉 |
|2020/01/13| 增加了配置管理功能 此功能不发表至测试环境 待保护机制以及服务重启机制发开完成后才会发表值测试环境 请自行 clone 且导入 sql 体验 |
|2020/02/21| 修改了 casbin 的自定义鉴权方法,使其完全支持 RESTFUL 的 /:params 以及?query= 的接口模式 |
|2020/03/17| 增加了验证码功能 使用了 @dchest/captcha库 |
1
pliex OP 项目思路被抄袭。。。然后被某金论坛推广了。。。心里有点不爽。。吃了不会写英文 readme 的亏
|
2
xiaogouxo 2020-03-25 13:44:40 +08:00
研究过你的项目,很不错,提供了很多思路,避免采坑。没想到这也能抄袭,支持楼主
|
4
tikazyq 2020-03-25 15:01:09 +08:00
不错,赞一个
|
7
pliex OP @kphcdr 这就不详细说明了,说不定就是巧了撞到一起了,能做的只能更快完善,做更多别人没有的功能出来,代码生成器撸一半了。
|
8
davichi2009 2020-03-26 09:45:56 +08:00
gorm 和 xorm 比有什么优势吗?
|
9
davichi2009 2020-03-26 09:46:38 +08:00
验证码 我觉得可以单独设置一个开关
|
10
kwoktung 2020-03-26 10:56:51 +08:00 via Android
同是前端出身。最近搞搞 go 。赶紧 mark 参考一下。
|
11
pliex OP @davichi2009 支持国产
|
12
pliex OP @davichi2009 这个就需要前端一起进行环境变量配置了
|
14
davichi2009 2020-03-26 17:19:53 +08:00
@pliex 前端不需要吧 只要后端配置一下比如 环境是 dev 的就不校验验证码
|
15
pliex OP @davichi2009 前端需要配置 是否展示验证码输入框
|
16
pliex OP 已添加代码生成器和表单生成器功能
|