2 Star 1 Fork 0

依依四零七/微信令牌中控

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
middleware.go 1.72 KB
一键复制 编辑 原始数据 按行查看 历史
壹壹肆零柒 提交于 2020-08-26 09:46 +08:00 . 项目初始化
package middleware
import (
"github.com/sirupsen/logrus"
"net/http"
"time"
)
type Middleware struct {
Logger *logrus.Logger
}
func NewMiddleware(logger *logrus.Logger) *Middleware {
return &Middleware{Logger: logger}
}
func (m *Middleware) CORSMiddleware(next http.Handler) http.Handler {
fn := func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Access-Control-Allow-Origin", "*")
next.ServeHTTP(w, r)
}
return http.HandlerFunc(fn)
}
func (m *Middleware) SignMiddleware(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
var err error
accessSign := &Signature{}
accessSign.AppKey = r.Header.Get("AppKey")
accessSign.Nonce = r.Header.Get("Nonce")
accessSign.CheckSum = r.Header.Get("CheckSum")
accessSign.CurTime = r.Header.Get("CurTime")
if err = accessSign.CheckSignature(); err != nil {
w.WriteHeader(http.StatusForbidden)
_, _ = w.Write([]byte(err.Error()))
return
}
next.ServeHTTP(w, r)
})
}
func (m *Middleware) LoggingMiddleware(next http.Handler) http.Handler {
fn := func(w http.ResponseWriter, r *http.Request) {
t1 := time.Now()
next.ServeHTTP(w, r)
t2 := time.Now()
if nil != m.Logger {
m.Logger.Printf("[%s] %q %v", r.Method, r.URL.String(), t2.Sub(t1))
}
}
return http.HandlerFunc(fn)
}
func (m *Middleware) RecoverMiddleware(next http.Handler) http.Handler {
fn := func(w http.ResponseWriter, r *http.Request) {
defer func() {
if err := recover(); err != nil {
if nil != m.Logger {
m.Logger.Printf("Recover from panic: %+v", err)
}
http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError)
}
}()
next.ServeHTTP(w, r)
}
return http.HandlerFunc(fn)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/dh114007/wechat_token.git
git@gitee.com:dh114007/wechat_token.git
dh114007
wechat_token
微信令牌中控
ecb1187e7599

搜索帮助