内容简介:上篇关于我们先用一个简单的例子学习一下使用
上篇关于 Go模板库应用 的文章最后我们留下一个问题,页面模板是通过 CDN 引用的 BootStrap 的 css , js 文件。到目前位置我们的服务器还无法伺服客户端的静态文件请求把服务器磁盘上的文件响应给客户端。使用和配置过 Nginx 服务器的一定知道 Nginx 天然支持静态资源的访问,那么我们是不是也要借助 Nginx 才能实现处理静态文件请求呢?其实不是,在最开始的文章我们说过“Go语言不需要依赖任何第三方组件就能构建并启动一个高并发的 HTTP 服务器。”,这篇文章就让我们了解一下如何用 Go 语言的 net/http 库实现处理静态资源请求的问题。
我们先用一个简单的例子学习一下使用 net/http 如何创建一个静态资源服务器,然后再应用到我们的 http_demo 项目中。
Go Web 编程系列的每篇文章的源代码都打了对应版本的软件包,供大家参考。公众号中回复 gohttp08 获取本文源代码
创建静态资源服务器
我们新建一个 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="stylesheet">
</head>
<body>
{{ template "nav" .}}
<div>
{{template "content" .}}
</div> <!-- /container -->
<script src="/static/js/bootstrap.min.js"></script>
</body>
</html>
然后重启服务器,访问之前的页面 http:localhost:/view/index ,验证一下我们的服务器现在是否能伺服静态文件的请求了。
页面样式正常,现在只要在服务器这个 assets 目录下的文件,我们都可以通过 http://localhost:8000/static/* 路径的 URL 访问到。
今天的文章对应的源码已经打包上传,公众号回复 gohhttp08 获取下载链接,赶快下载下来动手练习一下吧。如果文章能帮助到你,不要忘记转发、点在看分享给更多人啊。关注公众号每周第一时间获取文章更新。
前文回顾
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Docusaurus 1.0.13 发布,易于维护的静态网站创建工具
- Docusaurus 1.2.1 发布,易于维护的静态网站创建工具
- Flutter之使用Overlay创建全局Toast并静态调用
- 静态库遇到静态库
- 全局变量,静态全局变量,局部变量,静态局部变量
- Android NDK秘籍--编译静态库、调用静态库
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux命令行与shell脚本编程大全 第3版
[美]布鲁姆,布雷斯纳汉 / 门佳、武海峰 / 人民邮电出版社 / 2016-8-1 / CNY 109.00
这是一本关于Linux命令行与shell脚本编程的全方位教程,主要包括四大部分:Linux命令行,shell脚本编程基础,高级shell脚本编程,如何创建实用的shell脚本。本书针对Linux系统的最新特性进行了全面更新,不仅涵盖了详尽的动手教程和现实世界中的实用信息,还提供了与所学内容相关的参考信息和背景资料。通过本书的学习,你将轻松写出自己的shell脚本。一起来看看 《Linux命令行与shell脚本编程大全 第3版》 这本书的介绍吧!