5-Gin 静态文件服务 --[Gin 框架入门精讲与实战案例]
在使用 Gin 框架开发 Go 语言应用程序时,提供静态文件服务(如 HTML、CSS、JavaScript 文件等)是一个常见的需求。Gin 提供了简单的方法来设置静态文件的路由,使得你可以轻松地将这些资源提供给客户端。
使用 Static
方法
最直接的方式是使用 Gin 内置的 Static
方法。这个方法允许你指定一个 URL 前缀和一个包含静态文件的目录路径。当用户请求以指定前缀开头的 URL 时,Gin 将从对应的目录中查找并返回相应的静态文件。
下面是使用 Gin 框架的 Static
方法来提供静态文件服务的四个不同示例。每个示例展示了不同的应用场景和配置方式。
示例 1: 基本静态文件服务
这是最简单的用法,用于将一个目录中的所有静态文件映射到一个 URL 路径前缀。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 将 ./static 目录下的文件映射到 /static/ URL 前缀router.Static("/static", "./static")router.Run(":8080")
}
在这个例子中:
/static/
是 URL 的访问路径前缀。./static
是服务器上的静态文件所在目录。- 当用户访问如
http://localhost:8080/static/style.css
时,Gin 会从./static/style.css
文件中读取内容并返回给客户端。
示例 2: 提供 HTML 文件作为默认主页
有时候你可能想要在访问根路径(/
)时直接提供一个 HTML 文件作为默认主页。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 将 ./public/index.html 映射为默认主页router.StaticFile("/", "./public/index.html")// 其他静态文件仍然可以通过 /static 访问router.Static("/static", "./public/assets")router.Run(":8080")
}
在这个例子中:
router.StaticFile("/", "./public/index.html")
设置了根路径/
返回./public/index.html
文件。router.Static("/static", "./public/assets")
继续提供其他静态资源,例如 CSS 和 JavaScript 文件。
示例 3: 使用相对路径与绝对路径
你可以选择使用相对路径或绝对路径来指定静态文件的位置。这里展示了如何同时使用两种路径。
package mainimport ("github.com/gin-gonic/gin""os"
)func main() {router := gin.Default()// 使用相对路径router.Static("/relative", "./static-relative")// 获取当前工作目录,并构建绝对路径currentDir, _ := os.Getwd()absPath := currentDir + "/static-absolute"// 使用绝对路径router.Static("/absolute", absPath)router.Run(":8080")
}
在这个例子中:
/relative
路径前缀对应的是相对项目根目录的./static-relative
文件夹。/absolute
路径前缀对应的是通过os.Getwd()
获取到的当前工作目录加上static-absolute
文件夹的绝对路径。
示例 4: 结合模板渲染与静态文件服务
有时你可能会结合模板渲染和静态文件服务,以创建更复杂的 Web 应用程序。下面的例子展示了如何做到这一点。
package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {router := gin.Default()// 加载 HTML 模板router.LoadHTMLGlob("templates/*")// 定义 GET 路由来渲染模板router.GET("/", func(c *gin.Context) {c.HTML(http.StatusOK, "index.tmpl", nil)})// 提供静态文件服务router.Static("/static", "./static")router.Run(":8080")
}
在这个例子中:
router.LoadHTMLGlob("templates/*")
加载了templates
文件夹中的所有 HTML 模板文件。router.GET("/", ...)
定义了一个路由,当访问根路径时,它会渲染index.tmpl
模板。router.Static("/static", "./static")
提供了静态文件服务,允许模板引用这些静态资源(例如 CSS、JS 文件)。
通过这四个示例,你可以看到如何灵活地使用 Gin 的 Static
方法来满足不同的静态文件服务需求。无论是简单的文件夹映射、设置默认主页、处理相对与绝对路径,还是结合模板渲染,Gin 都提供了简单而强大的支持。
使用 StaticFS
方法自定义文件系统
如果你需要更灵活地控制静态文件的提供方式,比如使用虚拟文件系统或内存中的文件,可以使用 StaticFS
方法,并传递一个实现了 http.FileSystem
接口的对象。
使用 Gin 的 StaticFS
方法可以让你更灵活地控制静态文件的提供方式,比如通过自定义文件系统、内存中的文件系统或者第三方存储服务。下面是四个不同场景下的示例,展示了如何利用 StaticFS
方法。
示例 1: 使用 http.Dir
提供本地目录
虽然这是最基础的方式,但它展示了如何将 StaticFS
与标准库中的 http.Dir
结合使用,以提供本地文件系统的静态文件服务。
package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {router := gin.Default()// 使用 http.Dir 指向本地文件夹localDir := http.Dir("./static")// 使用 StaticFS 方法注册静态文件服务router.StaticFS("/static", localDir)router.GET("/", func(c *gin.Context) {c.String(http.StatusOK, "Visit /static/ to see the static files.")})router.Run(":8080")
}
在这个例子中:
http.Dir("./static")
创建了一个指向本地./static
文件夹的文件系统。router.StaticFS("/static", localDir)
将/static
路径映射到本地文件夹。
示例 2: 使用 zip
文件作为虚拟文件系统
你可以使用 Go 的 archive/zip
包和 http.FileSystem
接口来从 ZIP 文件中提供静态文件。这对于打包和分发应用程序非常有用。
package mainimport ("archive/zip""fmt""io/fs""net/http""os""github.com/gin-gonic/gin"
)// ZipFS 是一个实现了 fs.FS 接口的结构体,用于从 ZIP 文件读取文件。
type ZipFS struct {zr *zip.Reader
}// Open 实现了 fs.FS 接口的方法,根据提供的路径名打开文件。
func (zfs *ZipFS) Open(name string) (fs.File, error) {for _, f := range zfs.zr.File {if f.Name == name {return &zipFile{file: f}, nil}}return nil, &fs.PathError{Op: "open", Path: name, Err: os.ErrNotExist}
}// zipFile 包装了一个 zip.File 并实现了 fs.File 接口。
type zipFile struct {file *zip.Filerc io.ReadCloser
}// Stat 返回文件的信息。
func (zf *zipFile) Stat() (fs.FileInfo, error) {return zf.file.FileInfo(), nil
}// Read 实现了 fs.File 接口的方法。
func (zf *zipFile) Read(b []byte) (int, error) {if zf.rc == nil {var err errorzf.rc, err = zf.file.Open()if err != nil {return 0, err}}return zf.rc.Read(b)
}// Close 实现了 fs.File 接口的方法。
func (zf *zipFile) Close() error {if zf.rc != nil {return zf.rc.Close()}return nil
}func main() {router := gin.Default()// 打开 ZIP 文件zf, err := zip.OpenReader("static.zip")if err != nil {fmt.Fprintf(os.Stderr, "Error opening ZIP file: %v\n", err)return}defer zf.Close()// 创建一个新的 ZipFS 实例zipFS := &ZipFS{zr: &zf.Reader}// 使用 StaticFS 方法注册静态文件服务router.StaticFS("/static", http.FS(zipFS))router.GET("/", func(c *gin.Context) {c.String(http.StatusOK, "Visit /static/ to see the static files from ZIP.")})router.Run(":8080")
}
通过上述方法,你可以根据自己的需求选择最适合的方式来配置 Gin 框架中的静态文件服务。无论你是想简单地提供一个静态目录,还是需要更复杂的文件系统逻辑,Gin 都提供了足够的灵活性来满足这些需求。
使用 StaticFile
方法为单个文件提供服务
如果你想只为单个文件提供服务,而不是整个目录,可以使用 StaticFile
方法。这通常用于提供像 robots.txt
或 favicon.ico
这样的特定文件。
使用 Gin 的 StaticFile
方法可以非常方便地为单个文件提供服务。这在你想要为特定路径提供一个具体的文件(如 robots.txt
或 favicon.ico
)时特别有用。下面是四个不同场景下的示例,展示了如何利用 StaticFile
方法。
示例 1: 提供 favicon.ico
这是最简单的用法,用于将一个特定的图标文件映射到根路径下的 /favicon.ico
。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 将 ./static/favicon.ico 映射为 /favicon.icorouter.StaticFile("/favicon.ico", "./static/favicon.ico")router.Run(":8080")
}
在这个例子中:
/favicon.ico
是 URL 的访问路径。./static/favicon.ico
是服务器上的静态文件所在路径。- 当用户访问
http://localhost:8080/favicon.ico
时,Gin 会从./static/favicon.ico
文件中读取内容并返回给客户端。
示例 2: 提供 robots.txt
文件
有时候你需要为搜索引擎爬虫提供一个 robots.txt
文件来指定抓取规则。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 将 ./static/robots.txt 映射为 /robots.txtrouter.StaticFile("/robots.txt", "./static/robots.txt")router.Run(":8080")
}
在这个例子中:
/robots.txt
是 URL 的访问路径。./static/robots.txt
是服务器上的静态文件所在路径。- 当用户访问
http://localhost:8080/robots.txt
时,Gin 会从./static/robots.txt
文件中读取内容并返回给客户端。
示例 3: 提供 HTML 文件作为默认主页
你可以使用 StaticFile
方法来设置一个 HTML 文件作为默认主页,当用户访问根路径 (/
) 时直接提供这个文件。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 将 ./static/index.html 映射为根路径 /router.StaticFile("/", "./static/index.html")router.Run(":8080")
}
在这个例子中:
/
是 URL 的访问路径。./static/index.html
是服务器上的静态文件所在路径。- 当用户访问
http://localhost:8080/
时,Gin 会从./static/index.html
文件中读取内容并返回给客户端。
示例 4: 提供多个单个文件
如果你有多个需要单独映射的文件,可以多次调用 StaticFile
方法来实现。
package mainimport ("github.com/gin-gonic/gin"
)func main() {router := gin.Default()// 为多个单个文件提供服务router.StaticFile("/favicon.ico", "./static/favicon.ico")router.StaticFile("/robots.txt", "./static/robots.txt")router.StaticFile("/sitemap.xml", "./static/sitemap.xml")router.StaticFile("/humans.txt", "./static/humans.txt")router.Run(":8080")
}
在这个例子中:
- 每个
router.StaticFile
调用都指定了一个不同的 URL 路径和对应的本地文件路径。 - 这样可以确保每个特定路径都会返回相应的文件,例如:
http://localhost:8080/favicon.ico
返回./static/favicon.ico
http://localhost:8080/robots.txt
返回./static/robots.txt
http://localhost:8080/sitemap.xml
返回./static/sitemap.xml
http://localhost:8080/humans.txt
返回./static/humans.txt
通过这些示例,你可以看到如何灵活地使用 Gin 的 StaticFile
方法来为单个文件提供服务。无论是提供图标、文本文件还是 HTML 页面,StaticFile
方法都能简化你的路由配置,并确保用户能够正确访问这些资源。
相关文章:
5-Gin 静态文件服务 --[Gin 框架入门精讲与实战案例]
在使用 Gin 框架开发 Go 语言应用程序时,提供静态文件服务(如 HTML、CSS、JavaScript 文件等)是一个常见的需求。Gin 提供了简单的方法来设置静态文件的路由,使得你可以轻松地将这些资源提供给客户端。 使用 Static 方法 最直接…...

【自动驾驶】3 激光雷达③
5 激光雷达点云检测模型 🦋🦋🦋CenterPoint是Anchor‐Free的3D物体检测器,以点云作为输入,将三维物体在Bird‐View下的中心点作为关键点,基于关键点检测的方式回归物体的尺寸、方向和速度。相比于Anchor‐…...

Vue 3.5 编写 ref 时,自动插入.Value
如果是 Vue 3.2 ,那么可能用的是Volar...

从0到1实现一个RS蓝图系统-概念提出技术栈选型
请不要自我设限,真正好的人生态度,是现在就做,不等、不靠、不懒惰。 ——小野《改变力》 一、什么是蓝图? 蓝图(BluePrint) 是Epic Games 针对虚幻4引擎开发的可视化脚本语言。当你使用蓝图的时候,其实就是在编写代码…...
npm淘宝镜像
通过命令行配置npm的淘宝镜像源和官方镜像源,以及如何安装和使用cnpm来解决安装包卡顿或无法安装的问题。通过设置registry和disturl,配合清理缓存,可以优化npm的下载速度。 1、官方默认镜像 npm config set registry https://registry.n…...
深入解析:Python中的决策树与随机森林
在这个数据驱动的时代,机器学习技术已经成为许多企业和研究机构不可或缺的一部分。其中,决策树和随机森林作为两种强大的算法,在分类和回归任务中表现尤为出色。本文将带领大家深入了解这两种算法在Python中的实现,从基础到实战&a…...

奇怪问题| Chrome 访问csdn 创作中心的时候报错: 服务超时,请稍后重试
Chrome 访问csdn 创作中心的时候报错: 服务超时,请稍后重试用无痕浏览器可以正常访问 关闭代理无效清缓存和Cookies无效。考虑无痕浏览器模式下插件不生效,尝试把chrome 插件也禁用,发现有效,是该扩展程序的缘故...

【Leetcode】1705. 吃苹果的最大数目
文章目录 题目思路代码复杂度分析时间复杂度空间复杂度 结果总结 题目 题目链接🔗 有一棵特殊的苹果树,一连 n n n 天,每天都可以长出若干个苹果。在第 i i i 天,树上会长出 a p p l e s [ i ] apples[i] apples[i] 个苹果&a…...

职业技能赛赛后心得
这是一位粉丝所要求的,也感谢这位粉丝对我的支持。 那么本篇文章我也是分成四个部分,来总结一下这次赛后心得。 赛中问题 那么这里的赛中问题不会只包含我所遇到的问题,也会包含赛中其他选手出现的问题。 那么首先我先说一下我在赛中遇到的…...

从AI换脸到篡改图像,合合信息如何提升视觉内容安全?
本文目录 引言一、AI“真假之战”下的发展现状与考验挑战1.1 视觉内容安全现状与技术分类1.2视觉内容安全企业1.3视觉内容安全领域挑战 二、开山之石:引领视觉内容安全的创新之路2.1合合内容安全系统2.2发起编制相关技术规范2.3参与篡改检测挑战赛 三、视觉内容安全…...
c# 实现一个简单的异常日志记录(异常迭代+分片+定时清理)+AOP Rougamo全局注入
1. 日志目录和文件管理 日志目录:日志文件存储在 ./Exceptions 目录下。日志文件命名:日志文件的命名格式为 yyyy_MM_dd.log,表示当天的日期。如果当天的日志文件大小超过 maxFileSizeBytes(3KB),则会创建…...

webrtc学习----前端推流拉流,局域网socket版,一对多
提示:局域网socket版,一对多 文章目录 [TOC](文章目录) 前言一、教程二、webrtc工作流程三、推流端四、拉流五、socket服务六、效果七、备注总结 前言 WebRTC(Web Real-Time Communication)是一种实时通讯技术,允许网…...

美国加州房价数据分析01
1.项目简介 本数据分析项目目的是分析美国加州房价数据,预测房价中值。 环境要求: ancondajupyter notebookpython3.10.10 虚拟环境: pandas 2.1.1 numpy 1.26.1 matplotlib 3.8.0 scikit-learn1.3.1 2. 导入并探索数据集 通用的数据分析…...

用Python开启人工智能之旅(四)深度学习的框架和使用方法
第四部分:深度学习的框架和使用方法 用Python开启人工智能之旅(一)Python简介与安装 用Python开启人工智能之旅(二)Python基础 用Python开启人工智能之旅(三)常用的机器学习算法与实现 用Pyt…...

两分钟解决:vscode卡在设置SSH主机,VS Code-正在本地初始化VSCode服务器
问题原因 remote-ssh还是有一些bug的,在跟新之后可能会一直加载初始化SSH主机解决方案 1.打开终端2.登录链接vscode的账号,到家目录下3.找到 .vscode-server文件,删掉这个文件4.重启 vscode 就没问题了...
信号仿真高级工程师面试题
信号仿真高级工程师面试题可能涵盖多个方面,旨在全面评估应聘者的专业知识、技能水平、实践经验和问题解决能力。以下是一些可能的面试题及其简要解析: 一、专业知识与技能 描述你对信号仿真的理解 考察点:对信号仿真基本概念、原理及应用的掌握程度。参考答案:信号仿真是…...
循环和迭代
从更高层次的思维角度来看迭代和循环的区别: 哲学层面: 迭代体现了"螺旋上升"的发展理念,每次迭代都在前一次的基础上有所提升和改进 循环体现了"周而复始"的概念,强调重复相同的过程 思维方式:…...
一个简单封装的的nodejs缓存对象
我们在日常编码中,经常会用到缓存,而一个有效的缓存管理,也是大家必不可少的工具。而nodejs没有内置专用的缓存对象,并且由于js的作用域链的原因,很多变量使用起来容易出错,如果用一个通用的缓存管理起来&a…...
【Rust自学】5.3. struct的方法(Method)
喜欢的话别忘了点赞、收藏加关注哦,对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 5.3.1. 什么是方法(Method) 方法和函数类似,也是用fn关键字进行声明,方法也有名称,也有参数ÿ…...
ChatGPT之父:奥尔特曼
奥尔特曼 阿尔特曼一般指萨姆奥尔特曼,他是OpenAI的联合创始人兼首席执行官,被称为“ChatGPT之父”.以下是其具体介绍: 个人经历 1985年4月22日出生于美国芝加哥,8岁学会编程,9岁拥有电脑,对信息技术和互联网产生兴趣.高中就读于约翰巴勒斯中学,后进入斯坦福大学主修计…...

3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...

2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...

视频字幕质量评估的大规模细粒度基准
大家读完觉得有帮助记得关注和点赞!!! 摘要 视频字幕在文本到视频生成任务中起着至关重要的作用,因为它们的质量直接影响所生成视频的语义连贯性和视觉保真度。尽管大型视觉-语言模型(VLMs)在字幕生成方面…...

SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现
摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序,以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务,提供稳定高效的数据处理与业务逻辑支持;利用 uniapp 实现跨平台前…...

相机从app启动流程
一、流程框架图 二、具体流程分析 1、得到cameralist和对应的静态信息 目录如下: 重点代码分析: 启动相机前,先要通过getCameraIdList获取camera的个数以及id,然后可以通过getCameraCharacteristics获取对应id camera的capabilities(静态信息)进行一些openCamera前的…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
Element Plus 表单(el-form)中关于正整数输入的校验规则
目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入(联动)2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

打手机检测算法AI智能分析网关V4守护公共/工业/医疗等多场景安全应用
一、方案背景 在现代生产与生活场景中,如工厂高危作业区、医院手术室、公共场景等,人员违规打手机的行为潜藏着巨大风险。传统依靠人工巡查的监管方式,存在效率低、覆盖面不足、判断主观性强等问题,难以满足对人员打手机行为精…...
在 Spring Boot 项目里,MYSQL中json类型字段使用
前言: 因为程序特殊需求导致,需要mysql数据库存储json类型数据,因此记录一下使用流程 1.java实体中新增字段 private List<User> users 2.增加mybatis-plus注解 TableField(typeHandler FastjsonTypeHandler.class) private Lis…...