Go语言实战案例:静态资源服务(CSS、JS、图片)

在 Web 开发中,除了提供 API 接口外,往往还需要对外提供静态资源服务,比如:

  • • CSS 样式文件
  • • JavaScript 脚本
  • • 图片、字体等静态资源

Go 的 net/http 包和 Gin 框架都提供了方便的方式来托管这些静态文件。

本篇我们将用 Gin 框架 演示如何快速构建一个静态资源服务。


一、功能目标

    1. 使用 Gin 提供一个静态资源目录,让用户能直接访问 CSS、JS、图片。
    1. 演示 HTML 页面引入这些静态资源。
    1. 支持前端直接访问 /static/... 路径获取文件。

二、项目结构

假设我们的项目目录结构如下:

arduino 复制代码
project/
│── main.go
│── static/
│     ├── css/
│     │    └── style.css
│     ├── js/
│     │    └── app.js
│     └── images/
│          └── logo.png
└── templates/
      └── index.html

三、代码实现

go 复制代码
package main

import (
    "github.com/gin-gonic/gin"
    "net/http"
)

func main() {
    r := gin.Default()

    // 1. 加载模板
    r.LoadHTMLGlob("templates/*")

    // 2. 提供静态文件服务
    //   /static 对应项目下的 static 目录
    r.Static("/static", "./static")

    // 3. 首页路由
    r.GET("/", func(c *gin.Context) {
        c.HTML(http.StatusOK, "index.html", nil)
    })

    // 启动服务器
    r.Run(":8080")
}

四、HTML 模板示例

templates/index.html

xml 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>静态资源示例</title>
    <!-- 引入 CSS -->
    <link rel="stylesheet" href="/static/css/style.css">
</head>
<body>
    <h1>欢迎来到 Go 静态资源服务示例</h1>
    <!-- 引入图片 -->
    <img src="/static/images/logo.png" alt="Logo" width="150">

    <!-- 引入 JS -->
    <script src="/static/js/app.js"></script>
</body>
</html>

五、静态资源示例

static/css/style.css

css 复制代码
body {
    background-color: #f5f5f5;
    font-family: Arial, sans-serif;
    text-align: center;
}
h1 {
    color: #333;
}

static/js/app.js

javascript 复制代码
document.addEventListener("DOMContentLoaded", function() {
    console.log("JavaScript 已加载");
});

六、运行与访问

运行服务:

go 复制代码
go run main.go

在浏览器访问:

arduino 复制代码
http://localhost:8080/

你会看到页面正常加载了 CSS 样式、图片和 JavaScript 脚本。

静态资源也可以直接访问:

bash 复制代码
http://localhost:8080/static/images/logo.png
http://localhost:8080/static/css/style.css

七、总结

  • • Gin 提供 Static() 方法一行就能完成静态文件托管。
  • • 静态文件路径映射和 URL 前缀可以灵活配置。
  • • 结合 HTML 模板,可以很方便地构建完整的前端页面服务。

相关推荐
kfaino2 小时前
码农的AI翻身(六)你好,我叫 Parameter
后端·aigc
掘金者阿豪2 小时前
把业务数据变成共享仪表盘:Metabase可视化与远程访问实践
前端·后端
猪猪拆迁队3 小时前
虚拟工厂仿真引擎的架构设计:让一条产线可编程、可观测、可干预
后端·ai编程
字节跳动数据库3 小时前
文章分享——相似函数处理方法
人工智能·后端·程序员
云技纵横3 小时前
@Transactional 失效的 7 种场景:第 5 种最难排查
后端
用户6757049885024 小时前
你知道 Go 结构体和结构体指针调用的区别吗?一文带你彻底搞懂!
后端·go
程序员cxuan4 小时前
读懂 Claude Code 架构分析系列,第一篇,开始!
人工智能·后端·架构
用户6757049885024 小时前
面试官问“装饰器模式”,这样回答薪资多要 3000!
后端
tntxia4 小时前
Geo Scene域名修改引起的一些问题
后端
用户298698530144 小时前
Java 实现 Word 文档加密与权限解除
java·后端