您好,登錄后才能下訂單哦!
這篇文章主要講解了“Golang GinWeb框架之如何使用靜態文件/模板渲染”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Golang GinWeb框架之如何使用靜態文件/模板渲染”吧!
靜態文件服務
package main import ( "github.com/gin-gonic/gin" "log" "net/http" "os" ) func main() { router := gin.Default() cwd, _ := os.Getwd() //獲取當前文件目錄 log.Printf("當前項目路徑:%s", cwd) router.Static("/static", cwd) //提供靜態文件服務器, 第一個參數為相對路徑,第二個參數為根路徑, 這個路徑一般放置css,js,fonts等靜態文件,前端html中采用/static/js/xxx或/static/css/xxx等相對路徑的方式引用 router.StaticFS("/more_static", http.Dir("./")) //將本地文件樹結構映射到前端, 通過瀏覽器可以訪問本地文件系統, 模擬訪問:http://localhost:8080/more_static router.StaticFile("/logo.png", "./resources/logo.png") //StaticFile提供單靜態單文件服務, 模擬訪問:http://localhost:8080/log.png // Listen and serve on 0.0.0.0:8080 router.Run(":8080") }
返回文件數據
package main import ( "github.com/gin-contrib/cors" "github.com/gin-gonic/gin" "net/http" ) func main() { router := gin.Default() router.Use(cors.Default()) router.GET("/local/file", func(c *gin.Context) { c.File("./main.go") }) // A FileSystem implements access to a collection of named files. // The elements in a file path are separated by slash ('/', U+002F) // characters, regardless of host operating system convention. // FileSystem接口, 要求實現文件的訪問的方法, 提供文件訪問服務根路徑的HTTP處理器 var fs http.FileSystem = http.Dir("./") //將本地目錄作為文件服務根路徑 router.GET("/fs/file", func(c *gin.Context) { c.FileFromFS("main.go", fs) //將文件服務系統下的文件數據返回 }) router.Run(":8080") } /* 模擬訪問文件數據: curl http://localhost:8080/local/file 模擬訪問文件系統下的文件數據: curl http://localhost:8080/fs/file */
用文件讀出器提供文件數據服務
package main import ( "github.com/gin-gonic/gin" "net/http" ) func main() { router := gin.Default() router.GET("/someDataFromReader", func(c *gin.Context) { response, err := http.Get("https://raw.githubusercontent.com/gin-gonic/logo/master/color.png") if err != nil || response.StatusCode != http.StatusOK { //請求鏈接中的文件出現錯誤時, 直接返回服務不可用 c.Status(http.StatusServiceUnavailable) return } reader := response.Body //用響應體內容構造一個文件讀出器 defer reader.Close() contentLength := response.ContentLength contentType := response.Header.Get("Content-Type") extraHeaders := map[string]string{ "Content-Disposition": `attachment; filename="gopher.png"`, } // DataFromReader writes the specified reader into the body stream and updates the HTTP code. // func (c *Context) DataFromReader(code int, contentLength int64, contentType string, reader io.Reader, extraHeaders map[string]string) {} // DataFromReader方法將指定的讀出器reader中的內容, 寫入http響應體流中, 并更新響應碼, 響應頭信息等 c.DataFromReader(http.StatusOK, contentLength, contentType, reader, extraHeaders) }) router.Run(":8080") } /* 模擬訪問: curl http://localhost:8080/someDataFromReader */
HTML渲染
使用LoadHTMLGlob()方法或LoadHTMLFiles()方法
package main import ( "github.com/gin-gonic/gin" "net/http" ) func main() { router := gin.Default() //LoadHTMLGlob方法以glob模式加載匹配的HTML文件, 并與HTML渲染器結合 router.LoadHTMLGlob("templates/*") //router.LoadHTMLFiles("templates/template1.html", "templates/template2.html") router.GET("/index", func(c *gin.Context) { //HTML方法設置響應碼, 模板文件名, 渲染替換模板中的值, 設置響應內容類型Content-Type "text/html" c.HTML(http.StatusOK, "index.tmpl", gin.H{ "title": "Main website", }) }) router.Run(":8080") } /* 模擬測試: curl http://localhost:8080/index */
增加模板文件, templates/index.tmpl
<html> <h2> {{ .title }} </h2> </html>
使用不同文件夾下的相同文件名的模板文件
func main() { router := gin.Default() router.LoadHTMLGlob("templates/**/*") router.GET("/posts/index", func(c *gin.Context) { c.HTML(http.StatusOK, "posts/index.tmpl", gin.H{ "title": "Posts", }) }) router.GET("/users/index", func(c *gin.Context) { c.HTML(http.StatusOK, "users/index.tmpl", gin.H{ "title": "Users", }) }) router.Run(":8080") }
posts目錄下添加模板文件, templates/posts/index.tmpl
{{ define "posts/index.tmpl" }} <html><h2> {{ .title }} </h2> <p>Using posts/index.tmpl</p> </html> {{ end }}
users目錄下添加模板文件, templates/users/index.tmpl
{{ define "users/index.tmpl" }} <html><h2> {{ .title }} </h2> <p>Using users/index.tmpl</p> </html> {{ end }}
自定義模板渲染器
你也可以使用你自定義的HTML模板渲染器, 需要自定義模板文件file1, file2等
package main import ( "github.com/gin-gonic/gin" "html/template" "net/http" ) func main() { router := gin.Default() //template.ParseFiles(文件1,文件2...)創建一個模板對象, 然后解析一組模板,使用文件名作為模板的名字 // Must方法將模板和錯誤進行包裹, 返回模板的內存地址 一般用于變量初始化,比如:var t = template.Must(template.New("name").Parse("html")) html := template.Must(template.ParseFiles("file1", "file2")) router.SetHTMLTemplate(html) //關聯模板和HTML渲染器 router.GET("/index", func(c *gin.Context) { //HTML方法設置響應碼, 模板文件名, 渲染替換模板中的值, 設置響應內容類型Content-Type "text/html" c.HTML(http.StatusOK, "file1", gin.H{ "title": "Main website", }) }) router.Run(":8080") }
自定義分隔符
你可以自定義分隔符, 模板中默認的分隔符是{{ }}, 我們也可以修改, 比如下面增加一對中括號
r := gin.Default() r.Delims("{[{", "}]}") r.LoadHTMLGlob("/path/to/templates")
自定義模板方法
詳見 示例代碼.
模板中與后端都定義好模板方法, 模板渲染時執行該方法, 類似過濾器方法, 比如時間格式化操作
package main import ( "fmt" "html/template" "net/http" "time" "github.com/gin-gonic/gin" ) func formatAsDate(t time.Time) string { year, month, day := t.Date() //Date方法返回年,月,日 return fmt.Sprintf("%d%02d/%02d", year, month, day) //格式化時間 } func main() { router := gin.Default() router.Delims("{[{", "}]}") //自定義模板中的左右分隔符 //SetFuncMap方法用給定的template.FuncMap設置到Gin引擎上, 后面模板渲染時會調用同名方法 //FuncMap是一個map,鍵名關聯方法名, 鍵值關聯方法, 每個方法必須返回一個值, 或者返回兩個值,其中第二個是error類型 router.SetFuncMap(template.FuncMap{ "formatAsDate": formatAsDate, }) router.LoadHTMLFiles("./testdata/template/raw.tmpl") //加載單個模板文件并與HTML渲染器關聯 router.GET("/raw", func(c *gin.Context) { c.HTML(http.StatusOK, "raw.tmpl", gin.H{ "now": time.Date(2017, 07, 01, 0, 0, 0, 0, time.UTC), }) }) router.Run(":8080") } /* 模擬測試: curl http://localhost:8080/raw */
定義模板文件: raw.tmpl
Date: {[{.now | formatAsDate}]}
時間格式化結果:
Date: 2017/07/01
多個模板
Gin默認只使用一個html.Template模板引擎, 也可以參考多模板渲染器使用類似Go1.6的塊級模板block template功能.
模板相關詳情請參考官方template包
感謝各位的閱讀,以上就是“Golang GinWeb框架之如何使用靜態文件/模板渲染”的內容了,經過本文的學習后,相信大家對Golang GinWeb框架之如何使用靜態文件/模板渲染這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。