gf/net/ghttp/ghttp_server_log.go

79 lines
2.1 KiB
Go
Raw Normal View History

2020-12-30 13:18:43 +08:00
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
package ghttp
import (
2019-06-19 09:06:52 +08:00
"fmt"
2021-11-13 23:23:55 +08:00
2021-10-11 21:41:56 +08:00
"github.com/gogf/gf/v2/errors/gerror"
"github.com/gogf/gf/v2/text/gstr"
)
2020-05-07 23:05:33 +08:00
// handleAccessLog handles the access logging for server.
func (s *Server) handleAccessLog(r *Request) {
2019-06-19 09:06:52 +08:00
if !s.IsAccessLogEnabled() {
return
}
2022-03-09 21:27:02 +08:00
var (
scheme = "http"
proto = r.Header.Get("X-Forwarded-Proto")
)
if r.TLS != nil || gstr.Equal(proto, "https") {
2019-06-19 09:06:52 +08:00
scheme = "https"
}
2021-09-27 21:27:24 +08:00
s.Logger().File(s.config.AccessLogPattern).
2019-12-25 21:22:06 +08:00
Stdout(s.config.LogStdout).
Printf(
2021-09-27 21:27:24 +08:00
r.Context(),
2019-12-25 21:22:06 +08:00
`%d "%s %s %s %s %s" %.3f, %s, "%s", "%s"`,
r.Response.Status, r.Method, scheme, r.Host, r.URL.String(), r.Proto,
2019-12-25 21:22:06 +08:00
float64(r.LeaveTime-r.EnterTime)/1000,
r.GetClientIp(), r.Referer(), r.UserAgent(),
)
}
2020-05-07 23:05:33 +08:00
// handleErrorLog handles the error logging for server.
func (s *Server) handleErrorLog(err error, r *Request) {
2020-05-07 23:05:33 +08:00
// It does nothing if error logging is custom disabled.
2019-06-19 09:06:52 +08:00
if !s.IsErrorLogEnabled() {
return
}
var (
code = gerror.Code(err)
scheme = "http"
codeDetail = code.Detail()
2022-03-09 21:29:49 +08:00
proto = r.Header.Get("X-Forwarded-Proto")
codeDetailStr string
)
2022-03-09 21:29:49 +08:00
if r.TLS != nil || gstr.Equal(proto, "https") {
scheme = "https"
}
if codeDetail != nil {
codeDetailStr = gstr.Replace(fmt.Sprintf(`%+v`, codeDetail), "\n", " ")
}
content := fmt.Sprintf(
`%d "%s %s %s %s %s" %.3f, %s, "%s", "%s", %d, "%s", "%+v"`,
r.Response.Status, r.Method, scheme, r.Host, r.URL.String(), r.Proto,
float64(r.LeaveTime-r.EnterTime)/1000,
r.GetClientIp(), r.Referer(), r.UserAgent(),
code.Code(), code.Message(), codeDetailStr,
)
if s.config.ErrorStack {
if stack := gerror.Stack(err); stack != "" {
content += "\nStack:\n" + stack
} else {
content += ", " + err.Error()
}
} else {
content += ", " + err.Error()
}
2021-09-27 21:27:24 +08:00
s.Logger().File(s.config.ErrorLogPattern).
Stdout(s.config.LogStdout).
2021-09-27 21:27:24 +08:00
Print(r.Context(), content)
}