- Go + Gin + html/template 服务端渲染 - 主页:Google 风格搜索框 + 导航卡片 - 后台:卡片 CRUD、搜索引擎配置、主页背景/标题配置 - 图片上传:支持 jpg/jpeg/png/gif,自动压缩,缩略图参数 ?thumb=1 - 安全:登录日志、修改密码、IP 自动封禁、IP 白名单 - 访问统计:主页访问/卡片点击/搜索追踪、实时流量、IP 统计 - SQLite 存储(modernc.org/sqlite,纯 Go) - 内存 Session + bcrypt 密码哈希
36 lines
790 B
Go
36 lines
790 B
Go
package middleware
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"simple_portal/session"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
// AuthRequired returns a Gin middleware that checks for a valid session.
|
|
// If the session is invalid or missing, redirects to /admin/login.
|
|
func AuthRequired(store *session.SessionStore) gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
sessionID, err := c.Cookie("session_id")
|
|
if err != nil || sessionID == "" {
|
|
c.Redirect(http.StatusFound, "/admin/login")
|
|
c.Abort()
|
|
return
|
|
}
|
|
|
|
data := store.Get(sessionID)
|
|
if data == nil {
|
|
c.Redirect(http.StatusFound, "/admin/login")
|
|
c.Abort()
|
|
return
|
|
}
|
|
|
|
// Store session data in context for handlers to use
|
|
c.Set("adminID", data.AdminID)
|
|
c.Set("username", data.Username)
|
|
c.Set("sessionID", sessionID)
|
|
c.Next()
|
|
}
|
|
}
|