mirror of
				https://gitee.com/dromara/mayfly-go
				synced 2025-11-04 08:20:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			127 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package starter
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"errors"
 | 
						|
	"io/fs"
 | 
						|
	"mayfly-go/initialize"
 | 
						|
	"mayfly-go/internal/pkg/config"
 | 
						|
	"mayfly-go/pkg/i18n"
 | 
						|
	"mayfly-go/pkg/logx"
 | 
						|
	"mayfly-go/pkg/middleware"
 | 
						|
	"mayfly-go/pkg/req"
 | 
						|
	"mayfly-go/static"
 | 
						|
	"net/http"
 | 
						|
	"time"
 | 
						|
 | 
						|
	sysapp "mayfly-go/internal/sys/application"
 | 
						|
 | 
						|
	"github.com/gin-gonic/gin"
 | 
						|
)
 | 
						|
 | 
						|
func runWebServer(ctx context.Context) {
 | 
						|
	// 设置gin日志输出器
 | 
						|
	logOut := logx.GetConfig().GetLogOut()
 | 
						|
	gin.DefaultErrorWriter = logOut
 | 
						|
	gin.DefaultWriter = logOut
 | 
						|
 | 
						|
	// 权限处理器
 | 
						|
	req.UseBeforeHandlerInterceptor(req.PermissionHandler)
 | 
						|
	// 日志处理器
 | 
						|
	req.UseAfterHandlerInterceptor(req.LogHandler)
 | 
						|
	// 设置日志保存函数
 | 
						|
	req.SetSaveLogFunc(sysapp.GetSyslogApp().SaveFromReq)
 | 
						|
 | 
						|
	// jwt配置
 | 
						|
	jwtConf := config.Conf.Jwt
 | 
						|
	req.SetJwtConf(req.JwtConf{
 | 
						|
		Key:                    jwtConf.Key,
 | 
						|
		ExpireTime:             jwtConf.ExpireTime,
 | 
						|
		RefreshTokenExpireTime: jwtConf.RefreshTokenExpireTime,
 | 
						|
	})
 | 
						|
 | 
						|
	// i18n配置
 | 
						|
	i18n.SetLang(config.Conf.Server.Lang)
 | 
						|
 | 
						|
	// server配置
 | 
						|
	serverConfig := config.Conf.Server
 | 
						|
	gin.SetMode(serverConfig.Model)
 | 
						|
 | 
						|
	var router = gin.New()
 | 
						|
	router.MaxMultipartMemory = 8 << 20
 | 
						|
	// 初始化接口路由
 | 
						|
	initialize.InitRouter(router, initialize.RouterConfig{ContextPath: serverConfig.ContextPath})
 | 
						|
	// 设置静态资源
 | 
						|
	setStatic(serverConfig.ContextPath, router)
 | 
						|
	// 是否允许跨域
 | 
						|
	if serverConfig.Cors {
 | 
						|
		router.Use(middleware.Cors())
 | 
						|
	}
 | 
						|
 | 
						|
	srv := http.Server{
 | 
						|
		Addr: config.Conf.Server.GetPort(),
 | 
						|
		// 注册路由
 | 
						|
		Handler: router,
 | 
						|
	}
 | 
						|
 | 
						|
	go func() {
 | 
						|
		<-ctx.Done()
 | 
						|
		logx.Info("Shutdown HTTP Server ...")
 | 
						|
		timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second)
 | 
						|
		defer cancel()
 | 
						|
		err := srv.Shutdown(timeout)
 | 
						|
		if err != nil {
 | 
						|
			logx.Errorf("failed to Shutdown HTTP Server: %v", err)
 | 
						|
		}
 | 
						|
 | 
						|
		initialize.Terminate()
 | 
						|
	}()
 | 
						|
 | 
						|
	confSrv := config.Conf.Server
 | 
						|
	logx.Infof("Listening and serving HTTP on %s", srv.Addr+confSrv.ContextPath)
 | 
						|
	var err error
 | 
						|
	if confSrv.Tls != nil && confSrv.Tls.Enable {
 | 
						|
		err = srv.ListenAndServeTLS(confSrv.Tls.CertFile, confSrv.Tls.KeyFile)
 | 
						|
	} else {
 | 
						|
		err = srv.ListenAndServe()
 | 
						|
	}
 | 
						|
	if errors.Is(err, http.ErrServerClosed) {
 | 
						|
		logx.Info("HTTP Server Shutdown")
 | 
						|
	} else if err != nil {
 | 
						|
		logx.Errorf("Failed to Start HTTP Server: %v", err)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func setStatic(contextPath string, router *gin.Engine) {
 | 
						|
	// 使用embed打包静态资源至二进制文件中
 | 
						|
	fsys, _ := fs.Sub(static.Static, "static")
 | 
						|
	fileServer := http.FileServer(http.FS(fsys))
 | 
						|
	handler := WrapStaticHandler(http.StripPrefix(contextPath, fileServer))
 | 
						|
 | 
						|
	router.GET(contextPath+"/", handler)
 | 
						|
	router.GET(contextPath+"/favicon.ico", handler)
 | 
						|
	router.GET(contextPath+"/config.js", handler)
 | 
						|
	// 所有/assets/**开头的都是静态资源文件
 | 
						|
	router.GET(contextPath+"/assets/*file", handler)
 | 
						|
 | 
						|
	// 设置静态资源
 | 
						|
	if staticConfs := config.Conf.Server.Static; staticConfs != nil {
 | 
						|
		for _, scs := range *staticConfs {
 | 
						|
			router.StaticFS(scs.RelativePath, http.Dir(scs.Root))
 | 
						|
		}
 | 
						|
	}
 | 
						|
	// 设置静态文件
 | 
						|
	if staticFileConfs := config.Conf.Server.StaticFile; staticFileConfs != nil {
 | 
						|
		for _, sfs := range *staticFileConfs {
 | 
						|
			router.StaticFile(sfs.RelativePath, sfs.Filepath)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func WrapStaticHandler(h http.Handler) gin.HandlerFunc {
 | 
						|
	return func(c *gin.Context) {
 | 
						|
		c.Writer.Header().Set("Cache-Control", `public, max-age=31536000`)
 | 
						|
		h.ServeHTTP(c.Writer, c.Request)
 | 
						|
	}
 | 
						|
}
 |