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")
}