next-terminal/pkg/middleware/logger.go
2021-03-19 23:06:06 +08:00

98 lines
1.8 KiB
Go

package middleware
import (
"fmt"
"os"
"path"
"time"
"github.com/labstack/echo/v4"
"github.com/sirupsen/logrus"
)
func Logger() *logrus.Logger {
now := time.Now()
logFilePath := ""
if dir, err := os.Getwd(); err == nil {
logFilePath = dir + "/log/"
}
if err := os.MkdirAll(logFilePath, 0755); err != nil {
fmt.Println(err.Error())
}
logFileName := now.Format("2006-01-02") + ".log"
//日志文件
fileName := path.Join(logFilePath, logFileName)
if _, err := os.Stat(fileName); err != nil {
if _, err := os.Create(fileName); err != nil {
fmt.Println(err.Error())
}
}
//写入文件
src, err := os.OpenFile(fileName, os.O_APPEND|os.O_WRONLY, os.ModeAppend)
if err != nil {
fmt.Println("err", err)
}
//实例化
logger := logrus.New()
//设置输出
logger.Out = src
logger.SetOutput(os.Stdout)
//设置日志级别
logger.SetLevel(logrus.DebugLevel)
//logger.Out := fmt.
//设置日志格式
logger.SetFormatter(&logrus.TextFormatter{
TimestampFormat: "2006-01-02 15:04:05",
})
return logger
}
func LoggerToFile() echo.MiddlewareFunc {
logger := Logger()
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) (err error) {
if err = next(c); err != nil {
c.Error(err)
}
req := c.Request()
resp := c.Response()
startTime := time.Now()
// 处理请求
// 结束时间
endTime := time.Now()
// 执行时间
latencyTime := endTime.Sub(startTime)
// 请求方式
reqMethod := req.Method
// 请求路由
reqUri := req.URL
// 状态码
statusCode := resp.Status
// 请求IP
clientIP := req.RemoteAddr
//logger.Formatter
// TODO log Formatter
//日志格式
logger.Infof("| %3d | %13v | %15s | %s | %s |",
statusCode,
latencyTime,
clientIP,
reqMethod,
reqUri,
)
return
}
}
}