12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- // 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 (
- "fmt"
- "github.com/gogf/gf/errors/gerror"
- "github.com/gogf/gf/os/glog"
- )
- // Logger returns the logger of the server.
- func (s *Server) Logger() *glog.Logger {
- return s.config.Logger
- }
- // handleAccessLog handles the access logging for server.
- func (s *Server) handleAccessLog(r *Request) {
- if !s.IsAccessLogEnabled() {
- return
- }
- scheme := "http"
- if r.TLS != nil {
- scheme = "https"
- }
- s.Logger().File(s.config.AccessLogPattern).
- 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(),
- )
- }
- // handleErrorLog handles the error logging for server.
- func (s *Server) handleErrorLog(err error, r *Request) {
- // It does nothing if error logging is custom disabled.
- if !s.IsErrorLogEnabled() {
- return
- }
- 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 s.config.ErrorStack {
- if stack := gerror.Stack(err); stack != "" {
- content += "\nStack:\n" + stack
- } else {
- content += ", " + err.Error()
- }
- } else {
- content += ", " + err.Error()
- }
- s.config.Logger.
- File(s.config.ErrorLogPattern).
- Stdout(s.config.LogStdout).
- Print(content)
- }
|