Advanced Guide

Serving Static Files using GoFr

Often, we are required to serve static content such as a default profile image, a favicon, or a background image for our web application. We want to have a mechanism to serve that static content without the hassle of implementing it from scratch.

GoFr provides a default mechanism where if a static folder is available in the directory of the application, it automatically provides an endpoint with /static/<filename>, here filename refers to the file we want to get static content to be served.

Example project structure:

project_folder
|
|---configs
|       .env
|---static
|       img1.jpeg
|       img2.png
|       img3.jpeg
|   main.go
|   main_test.go

main.go code:

package main

import "gofr.dev/pkg/gofr"

func main() {
	app := gofr.New()
	app.Run()
}

Additionally, if we want to serve more static endpoints, we have a dedicated function called AddStaticFiles() which takes 2 parameters endpoint and the filepath of the static folder which we want to serve.

Example project structure:

project_folder
|
|---configs
|       .env
|---static
|       img1.jpeg
|       img2.png
|       img3.jpeg
|---public
|       |---css
|       |       main.css
|       |---js
|       |       main.js
|       |   index.html
|   main.go
|   main_test.go

main.go file:

package main

import "gofr.dev/pkg/gofr"

func main() {
	app := gofr.New()
	app.AddStaticFiles("public", "./public")
	app.Run()
}

In the above example, both endpoints /public and /static are available for the app to render the static content.

Previous
WebSockets