Gin 静态文件与同步异步
Gin 静态文件与同步异步
静态文件配置
当我们渲染的 HTML 文件中引用了静态文件时,我们需要配置静态 web 服务 r.Static(“/static”, “./static”) 前面的/static 表示路由 后面的./static 表示路径
开启static访问
//1 第一步:在路由中注册 r.Static("/static", "./static") 开启static访问 //2 第二步:项目路径新建static文件夹,css文件夹,common.css文件 h1{ background: aquamarine; color: black; } // 3 第三步:在pay.html中引入 <link rel="stylesheet" href="/static/css/common.css">
开启media访问
router.StaticFS("/media", http.Dir("./media")) // 网站小图标 router.StaticFile("/favicon.ico", "./resources/favicon.ico") // 访问 http://127.0.0.1:8000/media/
同步异步
-
goroutine机制可以方便地实现异步处理 另外,在启动新的goroutine时,不应该使用原始上下文,必须使用它的只读副本
package main import ( "github.com/gin-gonic/gin" "log" "time" ) func main() { r := gin.New() // 1.异步 r.GET("/long_async", func(c *gin.Context) { // 需要搞一个副本 copyContext := c.Copy() // 异步处理 go func() { time.Sleep(3 * time.Second) log.Println("异步执行:" + copyContext.Request.URL.Path) }() c.JSON(200,gin.H{ "msg":"异步请求成功"}) }) // 2.同步 r.GET("/long_sync", func(c *gin.Context) { time.Sleep(3 * time.Second) log.Println("同步执行:" + c.Request.URL.Path) c.JSON(200,gin.H{ "msg":"同步请求成功"}) }) r.Run(":8000") }