Use gin web framework to build your server
Let's build a simple web service using the Go programming language and the Gin web framework. We will define a basic web server that listens for incoming HTTP requests and responds with JSON data. The application would have a modular structure with separate files for the main application logic (main.go
), route handling (web/router.go
), and a specific route handler (web/assignments.go
).
├── go.mod
├── go.sum
├── main.go
└── web
├── assignments.go
└── router.go
2 directories, 5 files
Setup
Create a folder learn-Gin and inside it make an empty file main.go. After that run the command go mod init learn-gin
This will initialize a new Go module.
We also need to install Gin Web Framework, use the below command to get it from GitHub.
$ go get -u github.com/gin-gonic/gin
main.go
package main
import (
"log"
"learn-gin/web"
)
func main() {
r := web.Router()
log.Fatal(r.Run())
}
-
This is the entry point of the application.
-
It imports the
web
package, which contains the routing logic. -
In the
main
function, it initializes a router using theweb.Router()
function. -
The
r.Run
function starts the HTTP server and begins listening for incoming requests. -
If an error occurs while starting the server, the application will log the error using
log.Fatal()
.
web/assignments.go
package web
import (
"github.com/gin-gonic/gin"
)
type Assignments struct{}
func (a *Assignments) Index(c *gin.Context) {
c.JSON(200, gin.H{
"assignments": []string{},
})
}
-
This file defines a struct named
Assignments
. -
The
Assignments
struct does not have any fields, but it has a method namedIndex
associated with it. -
The
Index
method is a route handler function that accepts a Gin context (c *gin.Context
) as a parameter. -
When an HTTP GET request is made to the
/assignments
endpoint, theIndex
function responds with a JSON object containing an empty array under the "assignments" key.
web/router.go
package web
import (
"github.com/gin-gonic/gin"
)
func Router() *gin.Engine {
r := gin.Default()
asgns := Assignments{}
r.GET("/assignments", asgns.Index)
return r
}
-
This file defines a function named
Router
that creates and configures a Gin router. -
Inside the
Router
function, a new Gin router is created usinggin.Default()
. This sets up a basic router with default middleware, including logging and recovery. -
An instance of the
Assignments
struct is created. -
The
/assignments
endpoint is associated with theIndex
method of theAssignments
struct, so when a GET request is made to this endpoint, theIndex
function is called to handle the request. -
The function returns the configured router.
When you run the application, it starts an HTTP server that listens on a port (default is 8080), and when you access the /assignments
endpoint, it responds with a JSON object containing an empty array.
Thanks for reading
If you're interested in delving deeper into topics like DSA, Blockchain, and Backend, make sure to follow me on Twitter (@jyotirmoydotdev).