How to rewrite 404 in Golang
In Golang, rewriting the 404 error page is a common requirement, which can help us provide more friendly and personalized error prompts. In this article, PHP editor Xigua will introduce to you how to rewrite the 404 page in Golang. We will use the Gin framework to build web applications and handle 404 errors through custom middleware. Through the guidance of this article, you will learn how to rewrite the 404 page simply and quickly to improve user experience. let's start!
Question content
I'm still learning how to use Go for web development, but when I try to create a simple website, I face the following difficulties:
package main import ( "fmt" "html/template" "net/http" ) func main() { fs := http.FileServer(http.Dir("")) http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { tmpl, _ := template.ParseFiles("index.html") tmpl.Execute(w, nil) }) /** * This route will return a 404 error */ http.HandleFunc("/test", func(w http.ResponseWriter, r *http.Request) { fmt.Fprint(w, "Test page") }) /** * If I replace fs to nil, /test route will be work, but non-existent routes * will be return index.html template (home router) instead 404 error. Why? */ http.ListenAndServe(":80", fs) }
http.FileServer
and http.HandleFunc
.
For example, when I write: http.ListenAndServe(":80", nil)
, all routes (http.HandleFunc
) will work, but if I try to execute The following operations:
http.ListenAndServe(":80", http.FileServer(http.Dir("")))
No route is valid (except http.HandleFunc("/"))
. Why?
How to override 404 error page? I wish Go had a method like http.HandleError
which accepts interfaces http.ResponseWriter
and http.Request
but I can't find anything similar thing.
Solution
Check the documentation for http.ListenAndServe
:
If handler
is nil, the default handler http.HandleFunc
will be used:
So, in your code, you registered two routes using DefaultServeMux
; calling http.ListenAndServe(":80", nil)
uses the default handler (that you Routes added) so /test
works (more info below!). However, when you run http.ListenAndServe(":80", fs)
you are passing in a specific handler (fs
) so all requests will be sent to This handler (which will try to serve the file from the local file system).
From this point on, I'm going to assume that http.ListenAndServe(":80", nil)
is being used (since adding handlers and then not using them doesn't really make sense).
mentioned aboveServeMux
So let’s check the documentation:
So the Mux receives the request and figures out which handler should be called to handle the request (note that only one handler will be called). Matching is based on the length of the pattern (so in your example /test
is longer than /
and therefore takes precedence). This means that a request to /test
will trigger fmt.Fprint(w, "test page")
and everything else will call loading index.html
handler. Note that you have not added a handler that references fs
, so the handler is not used (and the code will not compile - Use http.FileServer to handle custom 404 pages
The above is the detailed content of How to rewrite 404 in Golang. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Since its inception in 2009, Bitcoin has become a leader in the cryptocurrency world and its price has experienced huge fluctuations. To provide a comprehensive historical overview, this article compiles Bitcoin price data from 2009 to 2025, covering major market events, changes in market sentiment, and important factors influencing price movements.

Bitcoin, as a cryptocurrency, has experienced significant market volatility since its inception. This article will provide an overview of the historical price of Bitcoin since its birth to help readers understand its price trends and key moments. By analyzing Bitcoin's historical price data, we can understand the market's assessment of its value, factors affecting its fluctuations, and provide a basis for future investment decisions.

Since its creation in 2009, Bitcoin’s price has experienced several major fluctuations, rising to $69,044.77 in November 2021 and falling to $3,191.22 in December 2018. As of December 2024, the latest price has exceeded $100,204.

Real-time Bitcoin USD Price Factors that affect Bitcoin price Indicators for predicting future Bitcoin prices Here are some key information about the price of Bitcoin in 2018-2024:

Important Node for Bitcoin Historical Price January 3, 2009: Genesis Block was generated, the first Bitcoin was generated, with a value of USD 0. October 5: The first Bitcoin transaction, a programmer bought two pizzas with 10,000 bitcoins, equivalent to $0.008. February 9, 2010: The Mt. Gox exchange went online and became the main platform for early Bitcoin trading. May 22: Bitcoin breaks through $1 for the first time. July 17: Bitcoin price plunged to $0.008, hitting an all-time low. February 9, 2011: Bitcoin price breaks through $10 for the first time. April 10: Mt. Go

Exception specifications in C++ can specify the types of exceptions that may be thrown by a function to ensure correct handling of exceptions. To use exception specifications, use the noexcept keyword in a function declaration, followed by a list of exception types. For example, in the divide function, use noexcept(std::invalid_argument) to specify that only invalid_argument exceptions may be thrown, ensuring that other exception types will cause compiler errors.

In C++ debugging, the solution to the third-party library dependency problem is as follows: verify that the dependency exists and is installed correctly; check whether the link flag is correctly specified; use the -L option to specify the library path; consider using dynamic linking; update the compiler version to resolve the dependency Compatibility issues; use a debugger to inspect the code line by line; check log files to understand the source of errors; update third-party libraries to the latest version; seek external support in the forum or contact the library maintainer.

Virtual currency funding rates are fees charged to traders holding positions in derivatives trading. It reflects a premium or discount between the spot market price and the futures contract price when the contract expires. When the spot price is higher than the futures price, the capital rate is negative, which means that traders who short positions pay fees to traders who long positions. On the contrary, when the spot price is lower than the futures price, the capital rate is positive, which means that traders who do long positions pay fees to traders who do short positions.
