gf/net/ghttp/ghttp_server_log.go

76 lines
1.9 KiB
Go
Raw Normal View History

// Copyright 2018 gf Author(https://github.com/gogf/gf). 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"
"github.com/gogf/gf/errors/gerror"
"github.com/gogf/gf/os/glog"
)
const (
gPATH_FILTER_KEY = "github.com/gogf/gf/"
)
// Logger returns the logger of the server.
func (s *Server) Logger() *glog.Logger {
return s.config.Logger
}
// 处理服务错误信息主要是panichttp请求的status由access log进行管理
func (s *Server) handleAccessLog(r *Request) {
2019-06-19 09:06:52 +08:00
if !s.IsAccessLogEnabled() {
return
}
scheme := "http"
if r.TLS != nil {
scheme = "https"
}
s.Logger().File(s.config.AccessLogPattern).
2019-12-25 21:22:06 +08:00
Stdout(s.config.LogStdout).
Printf(
`%d "%s %s %s %s %s" %.3f, %s, "%s", "%s"`,
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(),
)
}
// 处理服务错误信息主要是panichttp请求的status由access log进行管理
func (s *Server) handleErrorLog(err error, r *Request) {
2019-06-19 09:06:52 +08:00
// 错误输出默认是开启的
if !s.IsErrorLogEnabled() {
return
}
2019-06-19 09:06:52 +08:00
// 错误日志信息
scheme := "http"
if r.TLS != nil {
scheme = "https"
}
content := fmt.Sprintf(
`%d, "%s %s %s %s %s" %.3f, %s, "%s", "%s"`,
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(),
)
if stack := gerror.Stack(err); stack != "" {
content += "\nStack:\n" + stack
s.config.Logger.File(s.config.ErrorLogPattern).
2019-12-25 21:22:06 +08:00
Stack(false).
Stdout(s.config.LogStdout).
Error(content)
return
}
s.Logger().File(s.config.ErrorLogPattern).
Stack(s.config.ErrorStack).
StackWithFilter(gPATH_FILTER_KEY).
Stdout(s.config.LogStdout).
2019-12-25 21:22:06 +08:00
Error(content)
}