溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用Go語言創(chuàng)建靜態(tài)文件服務(wù)器問題

發(fā)布時間:2020-10-12 11:37:24 來源:腳本之家 閱讀:159 作者:Kevin · 欄目:編程語言

上篇關(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 目錄中搜索到請求的文件。

運行程序,然后用 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)文件的請求了。

使用Go語言創(chuàng)建靜態(tài)文件服務(wù)器問題

頁面樣式正常,現(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)文章希望大家以后多多支持億速云!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI