上篇關(guān)于Go模板庫應(yīng)用 的文章最后我們留下一個問題,頁面模板是通過 CDN 引用的 BootStrap 的 css , js 文件。到目前位置我們的服務(wù)器還無法伺服客戶端的靜態(tài)文件請求把服務(wù)器磁盤上的文件響應(yīng)給客戶端。使用和配置過 Nginx 服務(wù)器的一定知道 Nginx 天然支持靜態(tài)資源的訪問,那么我們是不是也要借助 Nginx 才能實現(xiàn)處理靜態(tài)文件請求呢?其實不是,在最開始的文章我們說過“Go語言不需要依賴任何第三方組件就能構(gòu)建并啟動一個高并發(fā)的 HTTP 服務(wù)器?!保@篇文章就讓我們了解一下如何用 Go 語言的 net/http 庫實現(xiàn)處理靜態(tài)資源請求的問題。
我們先用一個簡單的例子學(xué)習(xí)一下使用 net/http 如何創(chuàng)建一個靜態(tài)資源服務(wù)器,然后再應(yīng)用到我們的 http_demo 項目中。
創(chuàng)建靜態(tài)資源服務(wù)器
我們新建一個 main.go 存放創(chuàng)建靜態(tài)資源服務(wù)器和監(jiān)聽請求的代碼,同時在相同目錄下創(chuàng)建 assets/css 和 assets/js 目錄用于存放上篇文章頁面模板使用到的靜態(tài)文件。
main.go
assets/
└── css
└── bootstrap.min.css
└── js
└── bootstrap.min.js
main.go 中的代碼如下:
package main
import "net/http"
func main() {
fs := http.FileServer(http.Dir("assets/"))
http.Handle("/static/", http.StripPrefix("/static/", fs))
http.ListenAndServe(":8080", nil)
}
- 首先我們使用 http.FileServer 創(chuàng)建一個使用給定文件系統(tǒng)的內(nèi)容響應(yīng)所有 HTTP 請求的處理程序。
- http.Handle("/static/", http.StripPrefix("/static/", fs)) 讓文件服務(wù)器使用 assets 目錄下的文件響應(yīng) URL 路徑以 /static/ 開頭的所有 HTTP 請求。
- assets 被設(shè)置為文件服務(wù)器的文件系統(tǒng)根目錄,文件服務(wù)器會處理以 /static 開頭的 URL 的請求,所以我們需要使用 http.StripPrefix() 把 static 前綴去掉才能在 assets 目錄中搜索到請求的文件。
運(yùn)行程序,然后用 cURL 請求一下 css 文件,看看有沒有奏效。
$ go run main.go
$ curl -s http://localhost:8080/static/css/styles.css
/*!
* Bootstrap v3.3.7 (http://getbootstrap.com)
* Copyright 2011-2016 Twitter, Inc.
......
結(jié)合 gorillia/mux 使用文件服務(wù)器
上面的例子中文件服務(wù)器的處理程序是注冊到 net/http 庫提供的標(biāo)準(zhǔn)的 ServeMux (服務(wù)復(fù)用器)中的,我們 http_demo 項目為了支持復(fù)雜的路由注冊使用的是 gorillia/mux 庫提供的服務(wù)復(fù)用器。兩者的工作方式不太一樣,所以把文件服務(wù)器應(yīng)用到我們項目里還需要做些調(diào)整才能起作用。
首先我們先把 assets 目錄整個拷貝到項目的根目錄。
func RegisterRoutes(r *mux.Router) {
// serve static file request
fs := http.FileServer(http.Dir("assets/"))
serveFileHandler := http.StripPrefix("/static/", fs)
r.PathPrefix("/static/").Handler(serveFileHandler)
......
}
- 使用
router.PathPrefix("/static")
創(chuàng)建一個匹配有 /static 前綴請求的路由。
- 然后使用 route.Handler 方法將文件服務(wù)器注冊成路由對應(yīng)的處理程序( Handler 是 *mux.Route 上的方法)。
注冊好文件服務(wù)器后,我們把之前頁面模板引用的 CDN 上的 js 和 css 文件換成自己服務(wù)器上的文件鏈接。
html lang="en">
head>
......
link href="/static/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet">
/head>
body>
{{ template "nav" .}}
div class="container">
{{template "content" .}}
/div> !-- /container -->
script src="/static/js/bootstrap.min.js">/script>
/body>
/html>
然后重啟服務(wù)器,訪問之前的頁面 http:localhost:/view/index ,驗證一下我們的服務(wù)器現(xiàn)在是否能伺服靜態(tài)文件的請求了。
頁面樣式正常,現(xiàn)在只要在服務(wù)器這個 assets 目錄下的文件,我們都可以通過 http://localhost:8000/static/* 路徑的 URL 訪問到。
總結(jié)
到此這篇關(guān)于使用Go語言創(chuàng)建靜態(tài)文件服務(wù)器的文章就介紹到這了,更多相關(guān)go 靜態(tài)文件服務(wù)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- golang搭建靜態(tài)web服務(wù)器的實現(xiàn)方法
- golang實現(xiàn)http服務(wù)器處理靜態(tài)文件示例
- Go語言實現(xiàn)簡單的一個靜態(tài)WEB服務(wù)器