上篇關於Go模板庫應用的文章最後咱們留下一個問題,頁面模板是經過CDN
引用的BootStrap
的css
,js
文件。到目前位置咱們的服務器還沒法伺服客戶端的靜態文件請求把服務器磁盤上的文件響應給客戶端。使用和配置過Nginx
服務器的必定知道Nginx
自然支持靜態資源的訪問,那麼咱們是否是也要藉助Nginx
才能實現處理靜態文件請求呢?其實不是,在最開始的文章咱們說過「Go語言不須要依賴任何第三方組件就能構建並啓動一個高併發的 HTTP 服務器。」,這篇文章就讓咱們瞭解一下如何用Go
語言的net/http
庫實現處理靜態資源請求的問題。css
咱們先用一個簡單的例子學習一下使用net/http
如何建立一個靜態資源服務器,而後再應用到咱們的http_demo
項目中。html
Go Web 編程系列的每篇文章的源代碼都打了對應版本的軟件包,供你們參考。公衆號中回覆
gohttp08
獲取本文源代碼數據庫
咱們新建一個main.go
存放建立靜態資源服務器和監聽請求的代碼,同時在相同目錄下建立assets/css
和assets/js
目錄用於存放上篇文章頁面模板使用到的靜態文件。編程
main.go
assets/
└── css
└── bootstrap.min.css
└── js
└── bootstrap.min.js
複製代碼
main.go
中的代碼以下:bootstrap
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
建立一個使用給定文件系統的內容響應全部HTTP
請求的處理程序。http.Handle("/static/", http.StripPrefix("/static/", fs))
讓文件服務器使用assets
目錄下的文件響應URL
路徑以/static/
開頭的全部HTTP
請求。assets
被設置爲文件服務器的文件系統根目錄,文件服務器會處理以/static
開頭的URL
的請求,因此咱們須要使用http.StripPrefix()
把static
前綴去掉才能在assets
目錄中搜索到請求的文件。運行程序,而後用cURL
請求一下css
文件,看看有沒有奏效。bash
$ go run main.go
$ curl -s http://localhost:8080/static/css/bootstrap.min.css
/*!
* Bootstrap v3.3.7 (http://getbootstrap.com)
* Copyright 2011-2016 Twitter, Inc.
......
複製代碼
gorillia/mux
使用文件服務器上面的例子中文件服務器的處理程序是註冊到net/http
庫提供的標準的ServeMux
(服務複用器)中的,咱們http_demo
項目爲了支持複雜的路由註冊使用的是gorillia/mux
庫提供的服務複用器。二者的工做方式不太同樣,因此把文件服務器應用到咱們項目裏還須要作些調整才能起做用。服務器
首先咱們先把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")
建立一個匹配有/static
前綴請求的路由。route.Handler
方法將文件服務器註冊成路由對應的處理程序(Handler
是*mux.Route
上的方法)。註冊好文件服務器後,咱們把以前頁面模板引用的CDN
上的js
和css
文件換成本身服務器上的文件連接。curl
<html lang="en">
<head>
......
<link href="/static/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
{{ template "nav" .}}
<div class="container">
{{template "content" .}}
</div> <!-- /container -->
<script src="/static/js/bootstrap.min.js"></script>
</body>
</html>
複製代碼
而後重啓服務器,訪問以前的頁面http:localhost:/view/index
,驗證一下咱們的服務器如今是否能伺服靜態文件的請求了。高併發
頁面樣式正常,如今只要在服務器這個assets
目錄下的文件,咱們均可以經過http://localhost:8000/static/*
路徑的URL
訪問到。
今天的文章對應的源碼已經打包上傳,公衆號回覆gohttp08
獲取下載連接,趕快下載下來動手練習一下吧。若是文章能幫助到你,不要忘記轉發、點在看分享給更多人啊。關注公衆號每週第一時間獲取文章更新。
前文回顧