全局异常处理
This commit is contained in:
@@ -3,6 +3,7 @@ package cmd
|
||||
import (
|
||||
"TrangleAgent/internal/controller"
|
||||
"TrangleAgent/internal/controller/websocket"
|
||||
"TrangleAgent/internal/middleware"
|
||||
"context"
|
||||
|
||||
"github.com/gogf/gf/v2/frame/g"
|
||||
@@ -43,7 +44,7 @@ var (
|
||||
|
||||
// 注册 API 路由组
|
||||
s.Group("/api", func(group *ghttp.RouterGroup) {
|
||||
group.Middleware(ghttp.MiddlewareHandlerResponse)
|
||||
group.Middleware(middleware.ResponseHandler)
|
||||
controller.RegisterControllers(group)
|
||||
})
|
||||
|
||||
|
||||
65
Backend/internal/middleware/response.go
Normal file
65
Backend/internal/middleware/response.go
Normal file
@@ -0,0 +1,65 @@
|
||||
package middleware
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/gogf/gf/v2/errors/gcode"
|
||||
"github.com/gogf/gf/v2/errors/gerror"
|
||||
"github.com/gogf/gf/v2/net/ghttp"
|
||||
)
|
||||
|
||||
// ResponseHandler custom response handler to add "err" field
|
||||
func ResponseHandler(r *ghttp.Request) {
|
||||
r.Middleware.Next()
|
||||
|
||||
// There's custom buffer content, it then exits current handler.
|
||||
if r.Response.BufferLength() > 0 {
|
||||
return
|
||||
}
|
||||
|
||||
var (
|
||||
msg string
|
||||
err error
|
||||
code gcode.Code = gcode.CodeOK
|
||||
res = r.GetHandlerResponse()
|
||||
)
|
||||
if err = r.GetError(); err != nil {
|
||||
code = gerror.Code(err)
|
||||
if code == gcode.CodeNil {
|
||||
code = gcode.CodeInternalError
|
||||
}
|
||||
msg = err.Error()
|
||||
} else {
|
||||
if r.Response.Status > 0 && r.Response.Status != 200 {
|
||||
msg = http.StatusText(r.Response.Status)
|
||||
switch r.Response.Status {
|
||||
case 404:
|
||||
code = gcode.CodeNotFound
|
||||
case 403:
|
||||
code = gcode.CodeNotAuthorized
|
||||
default:
|
||||
code = gcode.CodeInternalError
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Custom response structure
|
||||
type Response struct {
|
||||
Code int `json:"code" dc:"Error code"`
|
||||
Message string `json:"message" dc:"Error message"`
|
||||
Data interface{} `json:"data" dc:"Result data for certain request according to model definition"`
|
||||
Err string `json:"err" dc:"Error details"`
|
||||
}
|
||||
|
||||
errStr := ""
|
||||
if err != nil {
|
||||
errStr = err.Error()
|
||||
}
|
||||
|
||||
r.Response.WriteJson(Response{
|
||||
Code: code.Code(),
|
||||
Message: msg,
|
||||
Data: res,
|
||||
Err: errStr,
|
||||
})
|
||||
}
|
||||
@@ -2,4 +2,5 @@ export interface ApiResponse {
|
||||
code?: number;
|
||||
message?: string;
|
||||
data?: any;
|
||||
err?: string;
|
||||
}
|
||||
|
||||
@@ -227,6 +227,11 @@ const fetchPosts = async () => {
|
||||
title: searchText.value || undefined
|
||||
})
|
||||
const data = (res as any).data || res || {}
|
||||
const errMsg = (res as any).err
|
||||
if (errMsg) {
|
||||
message.error(errMsg)
|
||||
return
|
||||
}
|
||||
posts.value = data.list || []
|
||||
total.value = data.total || 0
|
||||
} catch (error) {
|
||||
@@ -266,13 +271,20 @@ const handleCreatePost = async () => {
|
||||
|
||||
createLoading.value = true
|
||||
try {
|
||||
await postApiForumPostsCreate({
|
||||
const res = await postApiForumPostsCreate({
|
||||
boardId: Number("1"),//默认板块IDtodo
|
||||
userId: currentUserId.value,
|
||||
title: createForm.title,
|
||||
content: createForm.content,
|
||||
coverImage: createForm.coverImage,
|
||||
status: 'NORMAL'
|
||||
})
|
||||
const data = (res as any).data || res || {}
|
||||
const errMsg = (res as any).err
|
||||
if (errMsg) {
|
||||
message.error(errMsg)
|
||||
return
|
||||
}
|
||||
message.success('情报发布成功')
|
||||
createModalVisible.value = false
|
||||
fetchPosts()
|
||||
|
||||
Reference in New Issue
Block a user