Giter VIP home page Giter VIP logo

flipped-aurora / gin-vue-admin Goto Github PK

View Code? Open in Web Editor NEW
20.0K 287.0 6.0K 12.17 MB

🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器、表单生成器和可配置的导入导出等开发必备功能。

Home Page: http://demo.gin-vue-admin.com/

License: Apache License 2.0

Go 74.00% JavaScript 4.19% Vue 17.71% Smarty 3.21% Dockerfile 0.09% SCSS 0.62% Makefile 0.15% Shell 0.03%
gin-vue-admin gin vue golang vue-admin go-admin go admin gin-admin casbin

gin-vue-admin's Introduction

English | 简体中文

不同版本

我们会对以下四个版本持续维护,请选择适合自己的版本使用。最新技术栈为组合式api版本,已支持多语言(I18N)

组合式API版(主) | 组合式API多语言(i18n)版 | 声明式API版 | 声明式API多语言(i18n)版

项目文档

在线文档 : https://www.gin-vue-admin.com

初始化

从环境到部署教学视频

开发教学 (贡献者: LLemonGreen And Fann)

交流社区

插件市场

重要提示

1.本项目从起步到开发到部署均有文档和详细视频教程

2.本项目需要您有一定的golang和vue基础

3.您完全可以通过我们的教程和文档完成一切操作,因此我们不再提供免费的技术服务,如需服务请进行付费支持

4.如果您将此项目用于商业用途,请遵守Apache2.0协议并保留作者技术支持声明。您需保留如下版权声明信息,其余信息功能不做任何限制。如需剔除请购买授权

1. 基本介绍

1.1 项目介绍

Gin-vue-admin是一个基于 vuegin 开发的全栈前后端分离的开发基础平台,集成jwt鉴权,动态路由,动态菜单,casbin鉴权,表单生成器,代码生成器等功能,提供多种示例文件,让您把更多时间专注在业务开发上。

在线预览: http://demo.gin-vue-admin.com

测试用户名:admin

测试密码:123456

1.2 贡献指南

Hi! 首先感谢你使用 gin-vue-admin。

Gin-vue-admin 是一套为快速研发准备的一整套前后端分离架构式的开源框架,旨在快速搭建中小型项目。

Gin-vue-admin 的成长离不开大家的支持,如果你愿意为 gin-vue-admin 贡献代码或提供建议,请阅读以下内容。

1.2.1 Issue 规范

  • issue 仅用于提交 Bug 或 Feature 以及设计相关的内容,其它内容可能会被直接关闭。

  • 在提交 issue 之前,请搜索相关内容是否已被提出。

1.2.2 Pull Request 规范

  • 请先 fork 一份到自己的项目下,不要直接在仓库下建分支。

  • commit 信息要以[文件名]: 描述信息 的形式填写,例如 README.md: fix xxx bug

  • 如果是修复 bug,请在 PR 中给出描述信息。

  • 合并代码需要两名维护人员参与:一人进行 review 后 approve,另一人再次 review,通过后即可合并。

2. 使用说明

- node版本 > v16.8.3
- golang版本 >= v1.16
- IDE推荐:Goland

2.1 server项目

使用 Goland 等编辑工具,打开server目录,不可以打开 gin-vue-admin 根目录

# 克隆项目
git clone https://github.com/flipped-aurora/gin-vue-admin.git
# 进入server文件夹
cd server

# 使用 go mod 并安装go依赖包
go generate

# 编译 
go build -o server main.go (windows编译命令为go build -o server.exe main.go )

# 运行二进制
./server (windows运行命令为 server.exe)

2.2 web项目

# 进入web文件夹
cd web

# 安装依赖
npm install

# 启动web项目
npm run serve

2.3 swagger自动化API文档

2.3.1 安装 swagger

go install github.com/swaggo/swag/cmd/swag@latest

2.3.2 生成API文档

cd server
swag init

执行上面的命令后,server目录下会出现docs文件夹里的 docs.go, swagger.json, swagger.yaml 三个文件更新,启动go服务之后, 在浏览器输入 http://localhost:8888/swagger/index.html 即可查看swagger文档

2.4 VSCode工作区

2.4.1 开发

使用VSCode打开根目录下的工作区文件gin-vue-admin.code-workspace,在边栏可以看到三个虚拟目录:backendfrontendroot

2.4.2 运行/调试

在运行和调试中也可以看到三个task:BackendFrontendBoth (Backend & Frontend)。运行Both (Backend & Frontend)可以同时启动前后端项目。

2.4.3 settings

在工作区配置文件中有go.toolsEnvVars字段,是用于VSCode自身的go工具环境变量。此外在多go版本的系统中,可以通过gopathgo.goroot指定运行版本。

    "go.gopath": null,
    "go.goroot": null,

3. 技术选型

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

4. 项目架构

4.1 系统架构图

系统架构图

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

前端详细设计图

4.3 目录结构

    ├── server
        ├── api             (api层)
        │   └── v1          (v1版本接口)
        ├── config          (配置包)
        ├── core            (核心文件)
        ├── docs            (swagger文档目录)
        ├── global          (全局对象)                    
        ├── initialize      (初始化)                        
        │   └── internal    (初始化内部函数)                            
        ├── middleware      (中间件层)                        
        ├── model           (模型层)                    
        │   ├── request     (入参结构体)                        
        │   └── response    (出参结构体)                            
        ├── packfile        (静态文件打包)                        
        ├── resource        (静态资源文件夹)                        
        │   ├── excel       (excel导入导出默认路径)                        
        │   ├── page        (表单生成器)                        
        │   └── template    (模板)                            
        ├── router          (路由层)                    
        ├── service         (service层)                    
        ├── source          (source层)                    
        └── utils           (工具包)                    
            ├── timer       (定时器接口封装)                        
            └── upload      (oss接口封装)                        
    
            web
        ├── babel.config.js
        ├── Dockerfile
        ├── favicon.ico
        ├── index.html                 -- 主页面
        ├── limit.js                   -- 助手代码
        ├── package.json               -- 包管理器代码
        ├── src                        -- 源代码
        │   ├── api                    -- api 组
        │   ├── App.vue                -- 主页面
        │   ├── assets                 -- 静态资源
        │   ├── components             -- 全局组件
        │   ├── core                   -- gva 组件包
        │   │   ├── config.js          -- gva网站配置文件
        │   │   ├── gin-vue-admin.js   -- 注册欢迎文件
        │   │   └── global.js          -- 统一导入文件
        │   ├── directive              -- v-auth 注册文件
        │   ├── main.js                -- 主文件
        │   ├── permission.js          -- 路由中间件
        │   ├── pinia                  -- pinia 状态管理器,取代vuex
        │   │   ├── index.js           -- 入口文件
        │   │   └── modules            -- modules
        │   │       ├── dictionary.js
        │   │       ├── router.js
        │   │       └── user.js
        │   ├── router                 -- 路由声明文件
        │   │   └── index.js
        │   ├── style                  -- 全局样式
        │   │   ├── base.scss
        │   │   ├── basics.scss
        │   │   ├── element_visiable.scss  -- 此处可以全局覆盖 element-plus 样式
        │   │   ├── iconfont.css           -- 顶部几个icon的样式文件
        │   │   ├── main.scss
        │   │   ├── mobile.scss
        │   │   └── newLogin.scss
        │   ├── utils                  -- 方法包库
        │   │   ├── asyncRouter.js     -- 动态路由相关
        │   │   ├── btnAuth.js         -- 动态权限按钮相关
        │   │   ├── bus.js             -- 全局mitt声明文件
        │   │   ├── date.js            -- 日期相关
        │   │   ├── dictionary.js      -- 获取字典方法 
        │   │   ├── downloadImg.js     -- 下载图片方法
        │   │   ├── format.js          -- 格式整理相关
        │   │   ├── image.js           -- 图片相关方法
        │   │   ├── page.js            -- 设置页面标题
        │   │   ├── request.js         -- 请求
        │   │   └── stringFun.js       -- 字符串文件
        |   ├── view -- 主要view代码
        |   |   ├── about -- 关于我们
        |   |   ├── dashboard -- 面板
        |   |   ├── error -- 错误
        |   |   ├── example --上传案例
        |   |   ├── iconList -- icon列表
        |   |   ├── init -- 初始化数据  
        |   |   |   ├── index -- 新版本
        |   |   |   ├── init -- 旧版本
        |   |   ├── layout  --  layout约束页面 
        |   |   |   ├── aside 
        |   |   |   ├── bottomInfo     -- bottomInfo
        |   |   |   ├── screenfull     -- 全屏设置
        |   |   |   ├── setting        -- 系统设置
        |   |   |   └── index.vue      -- base 约束
        |   |   ├── login              --登录 
        |   |   ├── person             --个人中心 
        |   |   ├── superAdmin         -- 超级管理员操作
        |   |   ├── system             -- 系统检测页面
        |   |   ├── systemTools        -- 系统配置相关页面
        |   |   └── routerHolder.vue   -- page 入口页面 
        ├── vite.config.js             -- vite 配置文件
        └── yarn.lock

5. 主要功能

  • 权限管理:基于jwtcasbin实现的权限管理。
  • 文件上传下载:实现基于七牛云, 阿里云, 腾讯云 的文件上传操作(请开发自己去各个平台的申请对应 token 或者对应key)。
  • 分页封装:前端使用 mixins 封装分页,分页方法调用 mixins 即可。
  • 用户管理:系统管理员分配用户角色和角色权限。
  • 角色管理:创建权限控制的主要对象,可以给角色分配不同api权限和菜单权限。
  • 菜单管理:实现用户动态菜单配置,实现不同角色不同菜单。
  • api管理:不同用户可调用的api接口的权限不同。
  • 配置管理:配置文件可前台修改(在线体验站点不开放此功能)。
  • 条件搜索:增加条件搜索示例。
  • restful示例:可以参考用户管理模块中的示例API。
  • 多点登录限制:需要在config.yaml中把system中的use-multipoint修改为true(需要自行配置Redis和Config中的Redis参数,测试阶段,有bug请及时反馈)。
  • 分片上传:提供文件分片上传和大文件分片上传功能示例。
  • 表单生成器:表单生成器借助 @Variant Form
  • 代码生成器:后台基础逻辑以及简单curd的代码生成器。

6. 知识库

6.1 团队博客

https://www.yuque.com/flipped-aurora

内有前端框架教学视频。如果觉得项目对您有所帮助可以添加我的个人微信:shouzi_1994,欢迎您提出宝贵的需求。

6.2 教学视频

(1)手把手教学视频

https://www.bilibili.com/video/BV1Rg411u7xH/

(2)后端目录结构调整介绍以及使用方法

https://www.bilibili.com/video/BV1x44y117TT/

(3)golang基础教学视频

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

(4)gin框架基础教学

bilibili:https://space.bilibili.com/322210472/channel/detail?cid=126418&ctype=0

(5)gin-vue-admin 版本更新介绍视频

bilibili:https://www.bilibili.com/video/BV1kv4y1g7nT

7. 联系方式

7.1 技术群

QQ交流群:470239250

微信交流群

微信

防止广告进群,添加微信,输入以下代码执行结果(请勿转码为string)

str := "5Yqg5YWlR1ZB5Lqk5rWB576k"
decodeBytes, err := base64.StdEncoding.DecodeString(str)
fmt.Println(decodeBytes, err)

8. 贡献者

感谢您对gin-vue-admin的贡献!

9. 捐赠

如果你觉得这个项目对你有帮助,你可以请作者喝饮料 🍹 点我

10. 商用注意事项

如果您将此项目用于商业用途,请遵守Apache2.0协议并保留作者技术支持声明。

gin-vue-admin's People

Contributors

1319612909 avatar andywu1998 avatar bypanghu avatar felixsjiang avatar fengchao avatar garyfan avatar granty1 avatar haimait avatar hansonyu183 avatar hxcode avatar joewan avatar juwanxu avatar kilosonc avatar krank666 avatar maplepie avatar pixelmaxqm avatar qazwsx9288 avatar rikugun avatar ruio9244 avatar shadowwaiker avatar sliverhorn avatar songzhibin97 avatar suixinee avatar tingfeng-key avatar tscuite avatar wangleonard avatar wmvm0 avatar xue-ding-e avatar yaooort avatar zyw0605688 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

gin-vue-admin's Issues

前端项目缺少文件

'@/api/fileUploadAndDownload'
'@/utils/downloadImg'

期待 完成 "工作流,任务交接功能"

富文本编辑器的选择

为什么不选择Tinymce而是选择vue-quill-editor,我试了,简单的加粗,斜体都不行。。。。。。

建议

为什么超级管理员都没的权限,手动该数据库吗?

重构CreateTemp

初步想法是遍历resource/template文件夹下所有.tpl文件
根据该文件路径信息,实现当前功能(应该只需要很少的额外辅助信息 )
减少当前的重复代码,后续增加tpl文件也更方便

如果有需要我会进行这部分代码的重构,后续提交pr

数据库发生这种错误

[2020-04-25 15:06:54] sql: Scan error on column index 7, name "data_authority_id": unsupported Scan, storing driver.Value type []uint8 into type *[]model.SysAuthority

角色权限管理

您好,当前子角色能够选择所有权限。我觉得它只显示和获取父角色权限范围内的权限比较合理,这样应该要增加不少代码量

希望表单生成器可以添加 【多重输入】功能

大致功能为:
1.默认第一个输入框 右侧一个 ‘’+‘’ 的按钮
2.点击 “+”按钮,会向下创建一个输入框,同事当前输入框右侧生成有两个按钮 “+” “-”
3.点击 “-”按钮,会删除当前输入框
4. 第一个输入框始终只有一个 “+” 按钮

功能增强及建议

1:目前查询部分没有实现表所有字段模糊匹配功能
2:加载动画部分可以加在右侧的列表部分,只局部动画即可,现在全页面loading。。。觉得不太好
image
3:时间日期部分自动生成代码model部分没有引入time
4:生成model部分建议可以自定义表名,那么在生成架构体时灵活性更大了
类似这样
//get real table name
func (Example *Example) TableName() string {
return "example_table"
}
5:自动生成代码部分如果是布尔值时,那么前端部分需要自己实现布尔值的render功能
6:日期的处理,在前端建议给一个提示,或者在视频教学中说明(然并卵,建议生成模板时加提示吧)

无论如何,以上只是个人愚见,望采纳

为什么基本都是POST

您好,我粗略看了下api,发现method基本都是POST,请问是基于什么考量的呢,后续会考虑RESTful吗?

linux下docker快速部署方式

花了点时间,打包了一个docker镜像,方便在linux环境下快速部署

#启动容器
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;

vue 线上打包配置问题

前端我看到有个配置是vue.config.js 配置的是开发环境的一些参数。现在我想上线 在生产环境 我怎么新建一个生产配置和npm run build联系起来打包呢? 对前端不是很熟悉 希望解答下

自动生成代码

能否根据数据库表结自动生成相应model,controller,server等代码

BreakpointContinue

文件断点续传是不是还没有做完整,是不是要判断文件整个上传完成之后把文件切片删除。

我最迫切需求是,单表的 增删改查的从 service 里分离出来, 搞个单表万能查询接口,前端单表 也要搞个查询按钮

type {{Table}} struct {
{% for col in structArr %} {{col.key}} {{col.type}} json:"{{col.jsonTag}}"{% if col.sql %} sql:"{{col.sql}}"{% endif %} {% if !col.type %} // TODO: 类型判断错误,请自行选择类型 {% endif %}
{% endfor %}
}

const {{Table}}Table = "{{snake}}"

func Create{{Table}}(e *{{Table}}) *{{Table}} {
return DBCreate{{Table}}(DB({{Table}}Table), e)
}

func DBCreate{{Table}}(db *gorm.DB, e *{{Table}}) *{{Table}} {
err := db.Create(e).Error
if err != nil {
logger.Errorf("create {{table}} [%v] fails: %s", e, err.Error())
return nil
}
return e
}

func Update{{Table}}({{pk}} {{type}}, m map[string]interface{}) (*{{Table}}, int64, bool, error) {
return DBUpdate{{Table}}(DB({{Table}}Table), {{pk}}, m)
}

func DBUpdate{{Table}}(db gorm.DB, {{pk}} {{type}}, m map[string]interface{}) ({{Table}}, int64, bool, error) {
delete(m, "{{pk_snake}}")
delete(m, "ctime")
delete(m, "utime")

aff := db.Model(&{{Table}}{}).Where("{{pk_snake}} = ?", {{pk}}).UpdateColumns(m).RowsAffected
e := &{{Table}}{}
if err := db.Where("{{pk_snake}} = ?", {{pk}}).First(e).Error; err != nil {
	if err == gorm.ErrRecordNotFound {
		return nil, aff, false, nil
	} else {
		logger.Errorf("%v", err)
		return nil, aff, false, err
	}
}
return e, aff, true, nil

}

func Get{{Table}}({{pk}} {{type}}) *{{Table}} {
return DBGet{{Table}}(DB({{Table}}Table), {{pk}})
}

func DBGet{{Table}}(db *gorm.DB, {{pk}} {{type}}) *{{Table}} {
e := &{{Table}}{}
if err := db.Where("{{pk_snake}} = ?", {{pk}}).First(e).Error; err != nil {
logger.Errorf("get {{table}} [%d] fails: %s", {{pk}}, err.Error())
return nil
}
return e
}

func Get{{Table}}s(m map[string]interface{}) []*{{Table}} {
return DBGet{{Table}}s(DB({{Table}}Table), m)
}

func DBGet{{Table}}s(db gorm.DB, m map[string]interface{}) []{{Table}} {
result := []*{{Table}}{}
if err := db.Where(m).Find(&result).Error; err != nil {
logger.Errorf("get {{table}} with filter [%v] fails: %s", m, err.Error())
return nil
}
return result
}

func Get{{Table}}sBy{{Pk}}s({{pk}}s []{{type}}) []*{{Table}} {
return DBGet{{Table}}sBy{{Pk}}s(DB({{Table}}Table), {{pk}}s)
}

func DBGet{{Table}}sBy{{Pk}}s(db gorm.DB, {{pk}}s []{{type}}) []{{Table}} {
result := []*{{Table}}{}
if err := db.Where("{{pk_snake}} in (?)", {{pk}}s).Order("{{pk_snake}} asc").Find(&result).Error; err != nil {
logger.Errorf("get {{table}} with {{pk}}s %v fails: %s", {{pk}}s, err.Error())
return nil
}
return result
}

func Delete{{Table}}({{pk}} {{type}}) {
DBDelete{{Table}}(DB({{Table}}Table), {{pk}})
}

func DBDelete{{Table}}(db *gorm.DB, {{pk}} {{type}}){
if err := db.Where("{{pk_snake}} = ?", {{pk}}).Delete({{Table}}{}).Error; err != nil {
logger.Errorf("delete {{table}} [%d] fails: %s", {{pk}}, err.Error())

}

}

func Get{{Table}}sByOffset(offset int, m map[string]interface{}, rawq string, order int, ordcond string, limit int, getCount bool) ([]*{{Table}}, int) {
return DBGet{{Table}}sByOffset(DB({{Table}}Table), offset, m, rawq, order, ordcond, limit, getCount)
}

func DBGet{{Table}}sByOffset(db gorm.DB, offset int, m map[string]interface{}, rawq string, order int, ordcond string, limit int, getCount bool) ([]{{Table}}, int) {
totalCount := 0
result := make([]*{{Table}}, 0)
db = db.Model({{Table}}{})
if m != nil {
db = db.Where(m)
}
if len(rawq) > 0 {
db = db.Where(rawq)
}
if order > 0 {
db = db.Order("{{pk_snake}} asc")
} else if order < 0 {
db = db.Order("{{pk_snake}} desc")
} else if len(ordcond) > 0 {
db = db.Order(ordcond)
}
if getCount {
db.Count(&totalCount)
}
if limit > 0 {
db = db.Limit(limit)
}
if err := db.Offset(offset).Find(&result).Error; err != nil {
logger.Errorf("get {{table}} by offset fails: %s", err.Error)
return nil, 0
}
return result, totalCount
}

func Get{{Table}}sByTime(start time.Time, end time.Time, m map[string]interface{}, rawq string, limit int, getCount bool) ([]*{{Table}}, int) {
return DBGet{{Table}}sByTime(DB({{Table}}Table), start, end, m, rawq, limit, getCount)
}

func DBGet{{Table}}sByTime(db gorm.DB, start time.Time, end time.Time, m map[string]interface{}, rawq string, limit int, getCount bool) ([]{{Table}}, int) {
totalCount := 0
result := make([]*{{Table}}, 0)
db = db.Model({{Table}}{})
if m != nil {
db = db.Where(m)
}
if len(rawq) > 0 {
db = db.Where(rawq)
}
db = db.Where("ctime > ?", start)
if end.After(start) {
db = db.Where("ctime < ?", end)
}
if getCount {
db.Count(&totalCount)
}
if err := db.Order("ctime asc").Limit(limit).Find(&result).Error; err != nil {
logger.Errorf("get {{table}} by time fails: %s", err.Error())
return nil, 0
}
return result, totalCount
}

// Get{{Table}}sByFilter json 分页获取
// @param filter query string false "{"key":value}"
// @param pageSize query int false "PageSize"
// @param current query int false "Current"
// @success 200 {object} dao.{{Table}}
// @router /{{AppName}}/table/{{table}}sByFilter [get]
func Get{{Table}}sByFilter(c *gin.Context) {
current := c.MustGet("current").(int64)
pagesize := c.MustGet("pageSize").(int64)

jsonstring := c.MustGet("filter").(string)
filter := make(map[string]interface{})
err := json.Unmarshal([]byte(jsonstring), &filter)
if err != nil {
    c.JSON(http.StatusOK, &utils.Response{Code:e.INVALID_PARAMS,Msg:err.Error(),Data:nil})
    return
}
res, cnt := dao.Get{{Table}}sByOffset(
	int(uint(current-1))*int(pagesize),
	utils.MCamelToSnake(filter),
	"", 0, "", int(pagesize),true,
)
c.JSON(http.StatusOK, &utils.Response{Code: e.SUCCESS, Msg: "", Data: map[string]interface{}{
	"list": res,
	"count": cnt,
}})

}

关于Api的疑惑

首先感谢团队的开源项目!
体验自动生成代码功能过程中发现: 更新记录时提示“没有权限”,查看API,前端使用“PUT”更新方法,后端添加的更新方法是“POST”,这里应该是一个bug。

另外想问所有API都带有谓语 (貌似RESTful不提倡),出于何种考虑采用带谓语的API而不是如下形式

POST /posts
GET /posts
GET /posts/:id
POST /posts/:id
PUT /posts/:id
DELETE /posts/:id

初学者一枚,望作者指点迷津

希望提供 Validator 校验器功能

希望提供 Validator 校验器功能,此功能在参数校验时比较有用,此功能可以在参数与规则不匹配时,直接抛出错误信息

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.