Logo

dev-resources.site

for different kinds of informations.

Getting Started with Go and the Web: Hello, World!

Published at
12/29/2024
Categories
go
webdev
http
html
Author
markmunyaka
Categories
4 categories in total
go
open
webdev
open
http
open
html
open
Author
11 person written this
markmunyaka
open
Getting Started with Go and the Web: Hello, World!

Golang is growing in popularity as a server-side language. Developers use it as an alternative to more common technologies like PHP, Node.js, Ruby, Python, etc. One of the appeals of Go is its low resource usage. Developers on a budget can build powerful apps and host them cheaply on low-end infrastructure if they use Go.

This guide aims to gently introduce Go and see how it can be used to build applications for the web. This tutorial is aimed at beginners; however, experienced developers can also browse through it. You never know—you might learn a thing or two. Enough with the chit-chat, let's get started.

Prerequisites

To follow along with the guide, you need to have Go installed on your machine. Download and install Go by following the instructions: Download and Install Go.

Some knowledge of HTML is required for you to understand the concepts being illustrated. HTML is easy to catch on if you haven't written it before. Follow this guide if you haven't got a clue about HTML Learn HTML

Some knowledge of HTTP is required for you to understand the guide better. HTTP is the transport protocol for the web. Follow this guide to understand HTTP Learn HTTP

Hello World, Go

To get started with Go, open up your work folder and create a new file named main.go. Add the following code to main.go

package main

import "fmt"

func main() {
    fmt.Println("Hello, World!")
}
Enter fullscreen mode Exit fullscreen mode

Save the file and open up a new terminal session in your work directory. Run the following command:

go run main.go
Enter fullscreen mode Exit fullscreen mode

You should see the following output:

Hello, World!
Enter fullscreen mode Exit fullscreen mode

Congratulations! You have created your first program using Go. Pause and absorb the nice feeling. :) Now back to work.

That was just a warm up to get things started.

Hello World, Go on the Web

It's all well and good. We were able to print out "Hello, World!" on the terminal using Go, but that's not the aim of this guide. The real aim is to print out "Hello, World!" on a webpage using Go. So how do we do it?

First off, comment out the code you just wrote in main.go. At the top of your comment block, give it a ubiquitous name like "Step 1".

Above the comment block, add the following code:

package main

import "net/http"
import "fmt"

func main() {
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request){
        fmt.Fprintf(w, "<h1>Hello, World!</h1>")
    })

    http.ListenAndServe(":80", nil)
}
Enter fullscreen mode Exit fullscreen mode

Save the file and run it. Visit localhost in your browser and you should see the text "Hello, World!" on a webpage.

Hello World web page

Dynamic Hello

Awesome! We just managed to create a web server using Go and print the text "Hello, World!". The next step is to make the text change based on user input. Why? So that we understand the purpose of server side languages and how they can make our web pages dynamic.

Comment out the code you wrote in the previous step and at the top of the comment block give it a useful name like "Step 2".

Above the comment block add the following code:

package main

import "fmt"
import "net/http"

func main() {
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        if r.FormValue("q") != "" {
            fmt.Fprintf(w, `
                <body>
                    <h1>Hello, %s</h1>
                </body>
            `, r.FormValue("q"))
            return
        }
        fmt.Fprintf(w, `
            <body>
                <form action="/" method="GET">
                    <label>Enter your name</label>
                    <input name="q">
                    <button type="submit">Submit</button>
                </form>
            </body>
        `)
    })

    http.ListenAndServe(":80", nil)
}
Enter fullscreen mode Exit fullscreen mode

Stop your server (CTRL + C). Save the file and run it. Visit localhost in your browser and you should see a form input with the label, "Enter your name" and a "Submit" button.

Dynamic Web Page Go Form Input

Enter your name and click on "Submit". You should see the text "Hello, Jared", if your name is "Jared". Otherwise you will see the name you entered in the form.

Dynamic Web Page Go Form Result

Counter

Next, let's try something a different. How about a counter?

Comment out the code you wrote in the previous step and at the top of the comment block give it a useful name like "Step 3".

Above the comment block add the following code:

package main

import "fmt"
import "strconv"
import "net/http"

func main() {
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        if r.Method == "POST" {
            count, _ := strconv.Atoi(r.FormValue("counter"))
            count++
           fmt.Fprintf(w, `
            <body>
                <form action="/" method="POST">
                    <label>Counter</label>
                    <input name="counter" value="%d" readonly>
                    <button type="submit">Add</button>
                </form>
                <a href="/">Reset</a>
            </body>
        `, count)
        return
        }

        fmt.Fprintf(w, `
            <body>
                <form action="/" method="POST">
                    <label>Counter</label>
                    <input name="counter" value="1" readonly>
                    <button type="submit">Add</button>
                </form>
            </body>
            <a href="/">Reset</a>
        `)
        })

    http.ListenAndServe(":80", nil)
}
Enter fullscreen mode Exit fullscreen mode

Save the file and run it. Visit localhost in your browser and you should see a form input with the number "1" inside, the label, "Counter", and an "Add" button.

Dynamic Web Page Counter

Clicking the button should increase the value of the counter.

Conclusion

Congratulations! You've successfully built your first web application with Go, starting with a simple "Hello, World!" and progressing to a dynamic web page with user interaction. You've learned how to set up a basic web server, handle user input, and create a counter with Go. This is just the beginning—Go’s simplicity and efficiency make it a great choice for building scalable web applications.

As you continue exploring Go, you'll find many more advanced features and libraries that can help you build powerful and efficient applications. Keep experimenting and building, and soon you'll be mastering Go and creating complex web applications in no time. Happy coding!

Be on the look out for more tutorials. Ciao!

Resources

http Article's
30 articles in total
Favicon
Developing a Simple RESTful API with Gin, ginvalidator, and validatorgo
Favicon
[Boost]
Favicon
The OG of the Internet: How ARPANET's NCP Set the Stage for Our Digital World
Favicon
What data can crawlers collect through HTTP proxy IP?
Favicon
Getting Started with Go and the Web: Hello, World!
Favicon
What is HTTP?
Favicon
A checklist on how I approach technical SEO
Favicon
dotnet new project - assigning a port number
Favicon
API Destinations with Amazon EventBridge
Favicon
503 errors
Favicon
How to use a proxy in a nodejs environment
Favicon
Comprehensive Guide to OkHttp for Java and Kotlin
Favicon
What is HTTP 407 Status Code and How to Fix it
Favicon
HTTP Headers in API
Favicon
Guide to Cloudflare's Error Code 520 and How to Fix it
Favicon
What is HTTP 499 Status Code and How to Fix it?
Favicon
How to Use Postman Interceptor in Chrome | The Best Alternative
Favicon
Getting Started with Go and the Web: Deploy to Railway
Favicon
Understanding and Using HTTP Methods: GET, POST, PUT, DELETE
Favicon
Mastering Mock API Calls with Jest: A Comprehensive Tutorial
Favicon
HTTP Testing Tools for Mac in 2025
Favicon
HTTP requests
Favicon
HTTPX: Dump requests library in a junkyard 🚀
Favicon
Guide to SSL Errors: What do they mean and how to fix them
Favicon
What is the Best Way to Group REST API methods in Swagger UI
Favicon
How to use Cookies in Postman?
Favicon
Basic Auth vs. Bearer Token: Choosing the Best Authentication Method for Your API
Favicon
What is Error 1015 (Cloudflare) and How to Fix it?
Favicon
What HTTP Error 412 Precondition Failed and How to Fix it?
Favicon
Send a From Header When You Crawl

Featured ones: