生成表结构,开始实现接口逻辑

This commit is contained in:
2025-05-29 16:22:48 +08:00
parent a048f45aa3
commit e8a8e36d61
21 changed files with 277 additions and 211 deletions

View File

@ -1,27 +1,28 @@
package middleware
import (
"github.com/gogf/gf/v2/net/ghttp"
"server/utility/ecode"
"server/utility/myCasbin"
)
// Casbin 是用于访问权限控制的中间件。
//
// 该中间件基于 Casbin 权限控制框架,校验当前用户是否有权访问指定的 URL 和请求方法。
// 用户权限从请求上下文中的 "permission" 字段获取,该字段通常由前置中间件(如 Auth注入。
//import (
// "github.com/gogf/gf/v2/net/ghttp"
// "server/utility/ecode"
// "server/utility/myCasbin"
//)
//
// 参数:
//
// r *ghttp.Request - 当前的 HTTP 请求对象,由框架自动传入
//
// 行为:
// - 如果权限验证未通过终止请求返回权限不足的错误ecode.Denied
// - 如果权限验证通过:继续执行后续中间件或处理逻辑。
func Casbin(r *ghttp.Request) {
permission := r.GetCtxVar("permission").String()
if !myCasbin.GetMyCasbin().HasPermission(permission, r.URL.Path, r.Method) {
Exit(r, ecode.Denied)
}
r.Middleware.Next()
}
//// Casbin 是用于访问权限控制的中间件。
////
//// 该中间件基于 Casbin 权限控制框架,校验当前用户是否有权访问指定的 URL 和请求方法
//// 用户权限从请求上下文中的 "permission" 字段获取,该字段通常由前置中间件(如 Auth注入。
////
//// 参数:
////
//// r *ghttp.Request - 当前的 HTTP 请求对象,由框架自动传入。
////
//// 行为:
//// - 如果权限验证未通过终止请求返回权限不足的错误ecode.Denied)。
//// - 如果权限验证通过:继续执行后续中间件或处理逻辑。
//func Casbin(r *ghttp.Request) {
// permission := r.GetCtxVar("permission").String()
// if !myCasbin.GetMyCasbin().HasPermission(permission, r.URL.Path, r.Method) {
// Exit(r, ecode.Denied)
// }
// r.Middleware.Next()
//}

View File

@ -1,11 +1,54 @@
package middleware
import (
"github.com/gogf/gf/v2/errors/gcode"
"github.com/gogf/gf/v2/errors/gerror"
"github.com/gogf/gf/v2/net/ghttp"
"github.com/gogf/gf/v2/os/gctx"
"github.com/gogf/gf/v2/os/glog"
"github.com/gogf/gf/v2/util/gconv"
"net/http"
"server/utility/ecode"
)
// Response 统一响应中间件
func Response(r *ghttp.Request) {
r.Middleware.Next()
if r.Response.BufferLength() > 0 {
return
}
var (
msg string
err = r.GetError()
res = r.GetHandlerResponse()
code = gerror.Code(err)
)
glog.Debug(gctx.New(), "错误", err)
if err != nil {
if gconv.String(code.Detail()) != "customer" && code.Code() != 51 {
msg = ecode.Fail.Message()
} else if code.Code() == 51 {
msg = ecode.Params.Message()
} else {
msg = code.Message()
}
} else if r.Response.Status > 0 && r.Response.Status != http.StatusOK {
msg = http.StatusText(r.Response.Status)
switch r.Response.Status {
case http.StatusNotFound:
code = gcode.CodeNotFound
case http.StatusForbidden:
code = gcode.CodeNotAuthorized
default:
code = gcode.CodeUnknown
}
} else {
code = gcode.CodeOK
}
r.Response.WriteJson(ghttp.DefaultHandlerResponse{
Code: code.Code(),
Message: msg,
Data: res,
})
}