baishaojie 2ebf87524f 配方模板调整 | 4 月之前 | |
---|---|---|
comm | 1 年之前 | |
conf | 4 月之前 | |
demo | 1 年之前 | |
dist | 5 月之前 | |
dist-tmr-20240619 | 5 月之前 | |
docs | 1 年之前 | |
html | 1 年之前 | |
http | 4 月之前 | |
mdns | 1 年之前 | |
middleware | 1 年之前 | |
migration | 7 月之前 | |
models | 7 月之前 | |
module | 5 月之前 | |
pkg | 5 月之前 | |
scripts | 1 年之前 | |
service | 7 月之前 | |
test | 1 年之前 | |
uploads | 4 月之前 | |
.drone-bak.yml | 7 月之前 | |
.drone.yml | 5 月之前 | |
.gitignore | 1 年之前 | |
11111.sql | 5 月之前 | |
Dockerfile | 6 月之前 | |
KPTAdmin64.exe | 5 月之前 | |
LICENSE | 1 年之前 | |
Makefile | 7 月之前 | |
README.md | 1 年之前 | |
TMRWatchComm | 5 月之前 | |
TMRWatchComm.zip | 5 月之前 | |
__debug_bin.exe | 4 月之前 | |
dist-tmr-20240619.zip | 5 月之前 | |
go.mod | 6 月之前 | |
go.sum | 6 月之前 | |
linux64.bat | 1 年之前 | |
main.go | 1 年之前 | |
update.sql | 5 月之前 | |
win32.bat | 10 月之前 | |
win64.bat | 10 月之前 | |
yapi-mock.config.json | 4 月之前 |
一个go api 后端例子,包含JWT,RBAC(Casbin),增删改查, 一键生成 Restful API接口(不依赖orm)。
利用的casbin库, 将 user role menu 进行自动关联
项目启动时,会自动加载权限. 如有更改,会删除对应的权限,重新加载.
用户关联角色
角色关联菜单
权限关系为:
角色(role.name,menu.path,menu.method)
用户(user.username,role.name)
例如:
test /api/v1/users GET
zhuhongbin test
当zhuhongbin GET /api/v1/users 地址的时候,会去检查权限,因为他属于test组,同时组有对应权限,所以本次请求会通过。
用户 admin 有所有的权限,不进行权限匹配
登录接口 /auth 不进行验证
请求和接收 都是 传递 json 格式 数据
例如: 访问 /auth 获取token { "username": "admin", "password": "123456" } 访问 /api/v1/users 请求头设置 Authorization: Token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Create a go database and import SQL
创建一个库,然后导入sql,创建表!
You should modify conf/app.ini
[database]
Type = mysql
User = root
Password =
Host = 127.0.0.1:3306
Name = go
TablePrefix = go_
yum install go -y
cd $GOPATH/src/github.com/kptyun/go-admin
go build main.go
go run main.go
## 热编译,开发时使用
go get github.com/silenceper/gowatch
gowatch
Project information and existing API
[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- using env: export GIN_MODE=release
- using code: gin.SetMode(gin.ReleaseMode)
Listening port is 8000
默认 账户 密码 都为 123456
不用orm依赖,直接输入表名字就可以 增删改查
get http://127.0.0.1:8000/api/restful/go_user
get http://127.0.0.1:8000/api/restful/go_user/1
post http://127.0.0.1:8000/api/restful/go_user
数据格式 json 支持批量
[{
"username":"hequan",
"password":"hequan1",
"created_on": "0",
"modified_on":"0",
"deleted_on":"0"
}]
put http://127.0.0.1:8000/api/restful/go_user/2
数据格式 json
{
"password":"654321"
}
delete http://127.0.0.1:8000/api/restful/go_user/2
- RESTful API
- Gorm
- logging
- Jwt-go
- Swagger
- Gin
- Graceful restart or stop (fvbock/endless)
- App configurable
- 一键生成 Restful API接口
##更新注释
swag init
TODO 列表