为 Web UI 添加完整的登录验证系统,遵循 CQRS 架构模式。 主要功能: - 创建登录页面 UI (web/login.html) - 美观的渐变背景设计 - 密钥输入和验证 - 错误提示和加载状态 - 实现登录验证 (遵循 CQRS) - 新增 LoginQuery 和 LoginHandler (internal/api/handlers/auth_handlers.go) - 新增 AuthEndpoint (internal/api/endpoints/auth_endpoints.go) - 注册登录接口 /auth/login (无需授权) - 更新主页面 (web/index.html) - 添加登录状态检查 - 未登录显示提示信息 - 所有 API 请求自动携带 X-API-Key 头 - 添加退出登录功能 - 401 错误自动跳转登录页 - 更新路由配置 (cmd/server/main.go) - 添加 /auth/login 公开路由 - 注册登录处理器和端点 - 新增登录文档 (docs/LOGIN_GUIDE.md) - 完整的使用说明 - 技术实现细节 - API 接口说明 安全特性: - 密钥存储在 localStorage - 自动处理登录过期 - 支持主动退出登录 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
46 lines
1.0 KiB
Go
46 lines
1.0 KiB
Go
package endpoints
|
|
|
|
import (
|
|
"file-system/internal/api/handlers"
|
|
"file-system/internal/infrastructure/mediator"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
// AuthEndpoint 认证端点
|
|
type AuthEndpoint struct {
|
|
mediator *mediator.Mediator
|
|
}
|
|
|
|
// NewAuthEndpoint 创建认证端点
|
|
func NewAuthEndpoint(m *mediator.Mediator) *AuthEndpoint {
|
|
return &AuthEndpoint{
|
|
mediator: m,
|
|
}
|
|
}
|
|
|
|
// Login 用户登录
|
|
// @Summary 用户登录
|
|
// @Description 使用 API 密钥登录
|
|
// @Tags 认证
|
|
// @Accept json
|
|
// @Produce json
|
|
// @Param request body handlers.LoginQuery true "登录信息"
|
|
// @Success 200 {object} handlers.LoginResult
|
|
// @Router /auth/login [post]
|
|
func (e *AuthEndpoint) Login(c *gin.Context) {
|
|
var query handlers.LoginQuery
|
|
if err := c.ShouldBindJSON(&query); err != nil {
|
|
c.JSON(400, gin.H{"error": "请求参数错误"})
|
|
return
|
|
}
|
|
|
|
result, err := mediator.Send[handlers.LoginQuery, handlers.LoginResult](e.mediator, c.Request.Context(), query)
|
|
if err != nil {
|
|
c.JSON(500, gin.H{"error": err.Error()})
|
|
return
|
|
}
|
|
|
|
c.JSON(200, result)
|
|
}
|