通过使用 go-i18n 库和集成到 gin 框架,go 语言支持国际化(i18n),包括:翻译管理和选择。渲染翻译后的消息。将 i18n 集成到 web 框架中。根据用户语言设置提供多语言支持。
Go 中的国际化和多语言支持
国际化(i18n)和多语言支持是国际化 web 应用程序的重要组成部分。Go 语言提供了强大的库和工具,使开发者能够轻松地实现这些功能。
使用 go-i18n 库
立即学习“go语言免费学习笔记(深入)”;
go-i18n 是 Go 中一个流行的 i18n 库。它提供了易于使用的 API 来管理翻译、选择语言并渲染翻译后的消息。
import (
"fmt"
"<a style='color:#f60; text-decoration:underline;' href="https://www.php.cn/zt/15841.html" target="_blank">git</a>hub.com/nicksnyder/go-i18n/v2/i18n"
)
func main() {
bundle := i18n.NewBundle(i18n.LanguageCodes{"en", "es"})
bundle.AddTranslation("en", "Hello", "Hello")
bundle.AddTranslation("es", "Hello", "Hola")
localizer := i18n.NewLocalizer(bundle, "en")
fmt.Println(localizer.MustLocalize(&i18n.Message{
ID: "Hello",
Other: "world",
}))
}
集成到 Gin 框架
Gin 框架是一个流行的 Go web 框架。以下是如何将 i18n 集成到 Gin 中:
import (
"github.com/gin-gonic/gin"
"github.com/nicksnyder/go-i18n/v2/i18n"
)
func main() {
router := gin.Default()
bundle := i18n.NewBundle(i18n.LanguageCodes{"en", "es"})
bundle.AddTranslation("en", "Hello", "Hello")
bundle.AddTranslation("es", "Hello", "Hola")
router.GET("/hello", func(c *gin.Context) {
localizer := i18n.NewLocalizer(bundle, c.GetHeader("Accept-Language"))
c.String(200, localizer.MustLocalize(&i18n.Message{
ID: "Hello",
}))
})
router.Run()
}
实战案例
考虑一个名为 "message" 的简单 API,它返回基于用户语言设置的消息。
请求:
GET /message HTTP/1.1
Accept-Language: en
响应:
HTTP/1.1 200 OK
Content-Type: application/json
"Hello"
请求:
GET /message HTTP/1.1
Accept-Language: es
响应:
HTTP/1.1 200 OK
Content-Type: application/json
"Hola"