上篇关于Go模板库应用 的文章最后我们留下一个问题,页面模板是通过 CDN 引用的 BootStrap 的 css , js 文件。到目前位置我们的服务器还无法伺服客户端的静态文件请求把服务器磁盘上的文件响应给客户端。使用和配置过 Nginx 服务器的一定知道 Nginx 天然支持静态资源的访问,那么我们是不是也要借助 Nginx 才能实现处理静态文件请求呢?其实不是,在最开始的文章我们说过“Go语言不需要依赖任何第三方组件就能构建并启动一个高并发的 HTTP 服务器。”,这篇文章就让我们了解一下如何用 Go 语言的 net/http 库实现处理静态资源请求的问题。
我们先用一个简单的例子学习一下使用 net/http 如何创建一个静态资源服务器,然后再应用到我们的 http_demo 项目中。
创建静态资源服务器
我们新建一个 main.go 存放创建静态资源服务器和监听请求的代码,同时在相同目录下创建 assets/css 和 assets/js 目录用于存放上篇文章页面模板使用到的静态文件。
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 创建一个使用给定文件系统的内容响应所有 HTTP 请求的处理程序。
- http.Handle("/static/", http.StripPrefix("/static/", fs)) 让文件服务器使用 assets 目录下的文件响应 URL 路径以 /static/ 开头的所有 HTTP 请求。
- assets 被设置为文件服务器的文件系统根目录,文件服务器会处理以 /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. ......
结合 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 文件换成自己服务器上的文件链接。
<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="/UploadFiles/2021-04-08/bootstrap.min.js">然后重启服务器,访问之前的页面 http:localhost:/view/index ,验证一下我们的服务器现在是否能伺服静态文件的请求了。
页面样式正常,现在只要在服务器这个 assets 目录下的文件,我们都可以通过 http://localhost:8000/static/* 路径的 URL 访问到。
总结
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 梁汉文《不愿一个人》华星40金唱片[WAV分轨]
- 李宗盛《李宗盛精选滚石香港黄金十年》[WAV/分轨][670MB]
- 群星 模拟之声慢刻CD《发烧宝丽金35周年》[WAV+CUE][640MB]
- 《古惑仔系列电影合集1996-1998》[FLAC/分轨][780MB]
- 鸣潮自选4星武器推荐攻略 4星自选武器哪个最好
- 鸣潮自选5星武器怎么获取 五星自选武器哪个最好
- 鸣潮联觉等级怎么提升 联觉等级升级攻略
- 甄妮《皆因你的爱》华星40金唱片[WAV分轨]
- 陈奕迅《时代曲》华星40金唱片)[WAV分轨]
- 蔡依林《2004BornToBeAStar(超级珍藏世纪精选2CD)》[WAV整轨]
- 《碧海黑帆》新赛季预告公布 又有免费试玩生怕你不玩
- 刘德华《天王巨星经典情歌典藏2CD》[WAV+CUE][1.3GB]
- 斯琴格日乐《强烈直接的音乐方式 姿态》[WAV+CUE][500MB]
- 王菲《收录12首 只爱陌生人》[WAV+CUE][540MB]
- 鸣潮清芬鱼汤制作材料是什么 清芬鱼汤制作攻略分享