Files
hldrCenter/server/middleware/auth/auth.go

41 lines
993 B
Go
Raw Normal View History

2025-11-03 17:23:03 +08:00
package auth
import (
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/util/auth"
"github.com/gin-gonic/gin"
)
func AuthMiddleware() gin.HandlerFunc {
return func(c *gin.Context) {
sessionID := c.GetHeader("session_id")
if sessionID == "" { // 检查头是否为空
c.JSON(http.StatusUnauthorized, gin.H{
"code": 401,
"msg": "未登录,请先登录",
})
c.Abort()
return
}
// 2. 验证会话有效性调用你的ValidateSession函数
session, err := auth.ValidateSession(sessionID) // 假设该函数已存在,返回*Session和error
if err != nil {
// 会话无效(过期/已注销等返回401
c.JSON(http.StatusUnauthorized, gin.H{
"code": 401,
"msg": "会话无效或已过期,请重新登录",
})
c.Abort()
return
}
// 3. 会话有效将用户ID存入Gin上下文供后续处理器使用
// 后续handler可通过 c.Get("user_id") 获取
c.Set("user_id", session.UserID)
c.Next()
}
}