同步操作将从 二十四桥明月夜/IrisAdmin 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
Golang + Iris(web框架) + Casbin(权限) + JWT + Vue(渐进式js)
的web server框架,可前后端分离。
Iris的教程较少、零散、基础,且框架集合的完整实战案例极少(毕竟多数是用于工作,商业项目),几乎没有。后期可以直接使用。
源于开源,馈与社区。
称着还有精力在这方面。
QQ交流群:955576223
软件架构
目前支持单web架构,如果部署成前后端分离,可用nginx中间件代理(已添加跨域访问设置)。
- 采用了Casbin做Restful的rbac权限控制;
- 采用jwt做用户认证、回话控制;
- 采用Mysql+xorm做持久层;
- Vue前端项目持续更新中...,目前在front-vue分支;
go-iris
+-- a 该目录放的是临时的测试方法
+-- conf 所有的配置文件目录
+-- doc 说明文档(含go-bindata和mysql文件)
+-- exec_packahe 可执行的打包文件(目前只有win 64bit的打包)
+-- inits 所有需初始化的目录
| +-- parse 所有配置文件的初始化目录
| +-- init.go 用于初始化系统root用户,并注入所有service
+-- middleware 包含的中间件目录
| +-- casbins 用于rbac权限的中间件的目录
| +-- jwts jwt中间件目录
+-- resources 打包的前端静态资源文件
+-- utils 工具包目录
+-- web
| +-- db 数据库dao层目录
| +-- models 模型文件目录
| +-- routes 所有分发出来的路由的目录
| +-- supports 提供辅助方法的目录
+-- main.go 入口
/conf/app.yml
或/conf/db.yml
的配置后,都需要在项目下执行命令打包配置数据:go-bindata -pkg parse -o inits/parse/conf-data.go conf/
会生成/inits/parse/conf-data.go
数据文件(执行成功后不会有任何提示,则反之);go-bindata
的安装和使用教程在项目下的/doc/go-bindata-usage
文件中说明;/resources/*
前端文件;front-vue
分支代码vue >= 2.x
和node.js >= v8.9.3(LTS)
环境。IDE推荐安装webstonenpm install
安装本地前端环境npm run dev
启动本地前端环境npm run build
打包前端文件/resources/
目录下[[编译成当前环境]]
go install
[[编译成Linux 64bit]]
set CGO_ENABLED=0
set GOARCH=amd64
set GOOS=linux
go install
[[编译成Mac]]
set CGO_ENABLED=0
set GOARCH=amd64
set GOOS=darwin
go install
编译后的可执行文件在你本地go环境的GOPATH/bin/下找到。
/resources/*
前端目录文件 放在同一级目录中,执行go打包后的可执行文件,启动。如下图:
- 启动的本地服务地址:localhost:8088
- 超级用户登录:
初始账号:root
初始密码: 123456- 一般用户登录:
账号:yhm1
密码:123456
安装环境
- golang >= 1.9
- nginx 不必须
如果不使用前端环境,直接使用项目下的
/resource/*
的文件,则可以不需要下面的环境:
- vue >= 2.x
- node.js >= v8.9.3(LTS)
待需优化项,如:
- 前端静态文件数据打包
- 相同密码没随机加密
- 同一用户生成的token,生成两次前一次没失效
- 数据库连接池等等....
Golang + Iris(web框架) + Casbin(权限) + JWT + Vue(渐进式js)
的web server框架,可前后端分离。
Iris的教程较少、零散、基础,且框架集合的完整实战案例极少(毕竟多数是用于工作,商业项目),几乎没有。后期可以直接使用。
源于开源,馈与社区。
称着还有精力在这方面。
QQ交流群:955576223
软件架构
目前支持单web架构,如果部署成前后端分离,可用nginx中间件代理(已添加跨域访问设置)。
- 采用了Casbin做Restful的rbac权限控制;
- 采用jwt做用户认证、回话控制;
- 采用Mysql+xorm做持久层;
- Vue前端项目持续更新中...,目前在front-vue分支;
go-iris
+-- a 该目录放的是临时的测试方法
+-- conf 所有的配置文件目录
+-- doc 说明文档(含go-bindata和mysql文件)
+-- exec_packahe 可执行的打包文件(目前只有win 64bit的打包)
+-- inits 所有需初始化的目录
| +-- parse 所有配置文件的初始化目录
| +-- init.go 用于初始化系统root用户,并注入所有service
+-- middleware 包含的中间件目录
| +-- casbins 用于rbac权限的中间件的目录
| +-- jwts jwt中间件目录
+-- resources 打包的前端静态资源文件
+-- utils 工具包目录
+-- web
| +-- db 数据库dao层目录
| +-- models 模型文件目录
| +-- routes 所有分发出来的路由的目录
| +-- supports 提供辅助方法的目录
+-- main.go 入口
/conf/app.yml
或/conf/db.yml
的配置后,都需要在项目下执行命令打包配置数据:go-bindata -pkg parse -o inits/parse/conf-data.go conf/
会生成/inits/parse/conf-data.go
数据文件(执行成功后不会有任何提示,则反之);go-bindata
的安装和使用教程在项目下的/doc/go-bindata-usage
文件中说明;/resources/*
前端文件;front-vue
分支代码vue >= 2.x
和node.js >= v8.9.3(LTS)
环境。IDE推荐安装webstonenpm install
安装本地前端环境npm run dev
启动本地前端环境npm run build
打包前端文件/resources/
目录下[[编译成当前环境]]
go install
[[编译成Linux 64bit]]
set CGO_ENABLED=0
set GOARCH=amd64
set GOOS=linux
go install
[[编译成Mac]]
set CGO_ENABLED=0
set GOARCH=amd64
set GOOS=darwin
go install
编译后的可执行文件在你本地go环境的GOPATH/bin/下找到。
/resources/*
前端目录文件 放在同一级目录中,执行go打包后的可执行文件,启动。如下图:
- 启动的本地服务地址:localhost:8088
- 超级用户登录:
初始账号:root
初始密码: 123456- 一般用户登录:
账号:yhm1
密码:123456
安装环境
- golang >= 1.9
- nginx 不必须
如果不使用前端环境,直接使用项目下的
/resource/*
的文件,则可以不需要下面的环境:
- vue >= 2.x
- node.js >= v8.9.3(LTS)
待需优化项,如:
- 前端静态文件数据打包
- 相同密码没随机加密
- 同一用户生成的token,生成两次前一次没失效
- 数据库连接池等等....
f062733178f584d4966337090f7924c30633c783
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。