mirror of
https://github.com/woodchen-ink/proxy-go.git
synced 2025-07-18 08:31:55 +08:00
- Modify Dockerfile to copy web directory into /app - Update main.go to serve static and template files from absolute paths (/app/web) - Add debug logging for static file and template route handling - Ensure consistent file serving across admin and web routes
163 lines
4.4 KiB
Go
163 lines
4.4 KiB
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"os/signal"
|
|
"proxy-go/internal/compression"
|
|
"proxy-go/internal/config"
|
|
"proxy-go/internal/constants"
|
|
"proxy-go/internal/handler"
|
|
"proxy-go/internal/metrics"
|
|
"proxy-go/internal/middleware"
|
|
"strings"
|
|
"syscall"
|
|
)
|
|
|
|
func main() {
|
|
// 加载配置
|
|
cfg, err := config.Load("data/config.json")
|
|
if err != nil {
|
|
log.Fatal("Error loading config:", err)
|
|
}
|
|
|
|
// 更新常量配置
|
|
constants.UpdateFromConfig(cfg)
|
|
|
|
// 初始化指标收集器
|
|
if err := metrics.InitCollector(cfg); err != nil {
|
|
log.Fatal("Error initializing metrics collector:", err)
|
|
}
|
|
|
|
// 创建压缩管理器
|
|
compManager := compression.NewManager(compression.Config{
|
|
Gzip: compression.CompressorConfig(cfg.Compression.Gzip),
|
|
Brotli: compression.CompressorConfig(cfg.Compression.Brotli),
|
|
})
|
|
|
|
// 创建代理处理器
|
|
mirrorHandler := handler.NewMirrorProxyHandler()
|
|
proxyHandler := handler.NewProxyHandler(cfg)
|
|
|
|
// 创建处理器链
|
|
handlers := []struct {
|
|
matcher func(*http.Request) bool
|
|
handler http.Handler
|
|
}{
|
|
// 管理路由处理器
|
|
{
|
|
matcher: func(r *http.Request) bool {
|
|
return strings.HasPrefix(r.URL.Path, "/admin/")
|
|
},
|
|
handler: http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
log.Printf("[Debug] 处理管理路由: %s", r.URL.Path)
|
|
|
|
// 处理静态文件
|
|
if strings.HasPrefix(r.URL.Path, "/admin/static/") {
|
|
log.Printf("[Debug] 处理静态文件: %s", r.URL.Path)
|
|
http.StripPrefix("/admin/static/", http.FileServer(http.Dir("/app/web/static"))).ServeHTTP(w, r)
|
|
return
|
|
}
|
|
|
|
switch r.URL.Path {
|
|
case "/admin/login":
|
|
log.Printf("[Debug] 提供登录页面,文件路径: /app/web/templates/admin/login.html")
|
|
http.ServeFile(w, r, "/app/web/templates/admin/login.html")
|
|
case "/admin/metrics":
|
|
proxyHandler.AuthMiddleware(proxyHandler.MetricsHandler)(w, r)
|
|
case "/admin/config":
|
|
proxyHandler.AuthMiddleware(handler.NewConfigHandler(cfg).ServeHTTP)(w, r)
|
|
case "/admin/config/get":
|
|
proxyHandler.AuthMiddleware(handler.NewConfigHandler(cfg).ServeHTTP)(w, r)
|
|
case "/admin/config/save":
|
|
proxyHandler.AuthMiddleware(handler.NewConfigHandler(cfg).ServeHTTP)(w, r)
|
|
case "/admin/auth":
|
|
proxyHandler.AuthHandler(w, r)
|
|
default:
|
|
log.Printf("[Debug] 未找到管理路由: %s", r.URL.Path)
|
|
http.NotFound(w, r)
|
|
}
|
|
}),
|
|
},
|
|
// Mirror代理处理器
|
|
{
|
|
matcher: func(r *http.Request) bool {
|
|
return strings.HasPrefix(r.URL.Path, "/mirror/")
|
|
},
|
|
handler: mirrorHandler,
|
|
},
|
|
// 固定路径处理器
|
|
{
|
|
matcher: func(r *http.Request) bool {
|
|
for _, fp := range cfg.FixedPaths {
|
|
if strings.HasPrefix(r.URL.Path, fp.Path) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
},
|
|
handler: middleware.FixedPathProxyMiddleware(cfg.FixedPaths)(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {})),
|
|
},
|
|
// 默认代理处理器
|
|
{
|
|
matcher: func(r *http.Request) bool {
|
|
return true // 总是匹配,作为默认处理器
|
|
},
|
|
handler: proxyHandler,
|
|
},
|
|
}
|
|
|
|
// 创建主处理器
|
|
mainHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
log.Printf("[Debug] 收到请求: %s %s", r.Method, r.URL.Path)
|
|
|
|
// 处理静态文件
|
|
if strings.HasPrefix(r.URL.Path, "/web/static/") {
|
|
log.Printf("[Debug] 处理静态文件: %s", r.URL.Path)
|
|
http.StripPrefix("/web/static/", http.FileServer(http.Dir("/app/web/static"))).ServeHTTP(w, r)
|
|
return
|
|
}
|
|
|
|
// 遍历所有处理器
|
|
for _, h := range handlers {
|
|
if h.matcher(r) {
|
|
h.handler.ServeHTTP(w, r)
|
|
return
|
|
}
|
|
}
|
|
|
|
log.Printf("[Debug] 未找到处理器: %s", r.URL.Path)
|
|
http.NotFound(w, r)
|
|
})
|
|
|
|
// 添加压缩中间件
|
|
var handler http.Handler = mainHandler
|
|
if cfg.Compression.Gzip.Enabled || cfg.Compression.Brotli.Enabled {
|
|
handler = middleware.CompressionMiddleware(compManager)(handler)
|
|
}
|
|
|
|
// 创建服务器
|
|
server := &http.Server{
|
|
Addr: ":3336",
|
|
Handler: handler,
|
|
}
|
|
|
|
// 优雅关闭
|
|
go func() {
|
|
sigChan := make(chan os.Signal, 1)
|
|
signal.Notify(sigChan, syscall.SIGINT, syscall.SIGTERM)
|
|
<-sigChan
|
|
log.Println("Shutting down server...")
|
|
if err := server.Close(); err != nil {
|
|
log.Printf("Error during server shutdown: %v\n", err)
|
|
}
|
|
}()
|
|
|
|
// 启动服务器
|
|
log.Println("Starting proxy server on :3336")
|
|
if err := server.ListenAndServe(); err != http.ErrServerClosed {
|
|
log.Fatal("Error starting server:", err)
|
|
}
|
|
}
|