main.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package main
  2. import (
  3. "fmt"
  4. "runtime"
  5. "time"
  6. _ "hongze/hongze_admin/routers"
  7. "hongze/hongze_admin/utils"
  8. "github.com/astaxie/beego"
  9. "github.com/astaxie/beego/context"
  10. "github.com/astaxie/beego/logs"
  11. )
  12. func main() {
  13. if beego.BConfig.RunMode == "dev" {
  14. beego.BConfig.WebConfig.DirectoryIndex = true
  15. beego.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
  16. }
  17. beego.BConfig.RecoverFunc = Recover
  18. beego.Run()
  19. }
  20. func Recover(ctx *context.Context) {
  21. if err := recover(); err != nil {
  22. if err == beego.ErrAbort {
  23. return
  24. }
  25. if !beego.BConfig.RecoverPanic {
  26. panic(err)
  27. }
  28. stack := ""
  29. msg := fmt.Sprintf("The request url is %v", ctx.Input.URL())
  30. stack += msg + "</br>"
  31. logs.Critical(msg)
  32. msg = fmt.Sprintf("The request data is %v", string(ctx.Input.RequestBody))
  33. stack += msg + "</br>"
  34. logs.Critical(msg)
  35. msg = fmt.Sprintf("Handler crashed with error %v", err)
  36. stack += msg + "</br>"
  37. logs.Critical(msg)
  38. for i := 1; ; i++ {
  39. _, file, line, ok := runtime.Caller(i)
  40. if !ok {
  41. break
  42. }
  43. logs.Critical(fmt.Sprintf("%s:%d", file, line))
  44. stack = stack + fmt.Sprintln(fmt.Sprintf("%s:%d</br>", file, line))
  45. }
  46. go utils.SendEmail(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05"), stack, utils.EmailSendToUsers)
  47. }
  48. return
  49. }