123456789101112131415161718192021222324252627282930313233343536373839 |
- package logger
- import (
- "github.com/gin-gonic/gin"
- "net/http"
- "runtime/debug"
- )
- func Recover(c *gin.Context) {
- defer func() {
- if r := recover(); r != nil {
-
- Logger.Errorf("panic: %v\n", r)
- debug.PrintStack()
-
-
-
- c.JSON(http.StatusOK, gin.H{
- "code": 500,
- "msg": errorToString(r),
- "data": nil,
- })
-
- c.Abort()
- }
- }()
-
- c.Next()
- }
- func errorToString(r interface{}) string {
- switch v := r.(type) {
- case error:
- return v.Error()
- default:
- return r.(string)
- }
- }
|