使用結構體標籤自訂驗證錯誤訊息
在使用Gin 的Go Web 開發中,結構驗證在持久化之前確保數據完整性方面起著至關重要的作用。然而,底層驗證庫提供的預設錯誤訊息可能很冗長且不太用戶友好。本文探討如何根據結構體標籤傳回自訂錯誤訊息,讓開發者能夠向使用者提供更有意義、更可操作的回饋。
理解 Validator.ValidationErrors
Gin 利用用於驗證的 github.com/go-playground/validator/v10 函式庫。當驗證失敗時,會傳回 validator.ValidationErrors 類型的錯誤。此錯誤類型包含一個 validator.FieldError 實例片段,每個實例代表一個無效欄位。
自訂錯誤訊息
要自訂錯誤訊息,您可以解開驗證器。 ValidationErrors錯誤使用errors包,存取validator.FieldError,並根據欄位的標籤建構自訂錯誤訊息。結構體欄位中的 tag 屬性允許開發人員指定自訂驗證規則和錯誤訊息。
例如,考慮以下程式碼片段:
type ApiError struct { Field string Msg string } func msgForTag(tag string) string { switch tag { case "required": return "This field is required" case "email": return "Invalid email" } return "" }
此程式碼定義了一個 ApiError 結構體和一個輔助函數函數 msgForTag 將標籤對應到自訂錯誤訊息。使用它們,您可以實現以下處理程序:
var u User err := c.BindQuery(&u); if err != nil { var ve validator.ValidationErrors if errors.As(err, &ve) { out := make([]ApiError, len(ve)) for i, fe := range ve { out[i] = ApiError{fe.Field(), msgForTag(fe.Tag())} } c.JSON(http.StatusBadRequest, gin.H{"errors": out}) } return }
在此處理程序中,validator.ValidationErrors 錯誤被展開,並且每個validator.FieldError 都會轉換為帶有基於字段標籤的自定義訊息的ApiError 。然後對 ApiError 切片進行 JSON 編碼,並作為錯誤回應傳回,其中包含與欄位對應的動態鍵。
結論
透過使用結構標記自訂驗證錯誤訊息,開發人員可以在資料驗證期間提供更用戶友好且資訊豐富的回饋。這種方法增強了使用者體驗並簡化了偵錯過程,從而更容易識別和修正輸入錯誤。
以上是如何在 Go 中使用 Struct 標籤自訂驗證錯誤訊息?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Go語言使用"encoding/binary"包進行二進制編碼與解碼。 1)該包提供binary.Write和binary.Read函數,用於數據的寫入和讀取。 2)需要注意選擇正確的字節序(如BigEndian或LittleEndian)。 3)數據對齊和錯誤處理也是關鍵,確保數據的正確性和性能。

1)usebybytes.joinforconcatenatinges,2)bytes.bufferforincrementalwriting,3)bytes.indexorbytes.indexorbytes.indexbyteforsearching bytes.bytes.readereforrednorederencretingnchunknunknchunknunk.sss.inc.softes.4)

theencoding/binarypackageingoiseforporptimizingBinaryBinaryOperationsDuetoitssupportforendiannessessandefficityDatahandling.toenhancePerformance:1)usebinary.nativeendiandiandiandiandiandiandiandian nessideendian toavoid avoidByteByteswapping.2)

Go的bytes包主要用於高效處理字節切片。 1)使用bytes.Buffer可以高效進行字符串拼接,避免不必要的內存分配。 2)bytes.Equal函數用於快速比較字節切片。 3)bytes.Index、bytes.Split和bytes.ReplaceAll函數可用於搜索和操作字節切片,但需注意性能問題。

字節包提供了多種功能來高效處理字節切片。 1)使用bytes.Contains檢查字節序列。 2)用bytes.Split分割字節切片。 3)通過bytes.Replace替換字節序列。 4)用bytes.Join連接多個字節切片。 5)利用bytes.Buffer構建數據。 6)結合bytes.Map進行錯誤處理和數據驗證。

Go的encoding/binary包是處理二進制數據的工具。 1)它支持小端和大端字節序,可用於網絡協議和文件格式。 2)可以通過Read和Write函數處理複雜結構的編碼和解碼。 3)使用時需注意字節序和數據類型的一致性,尤其在不同系統間傳輸數據時。該包適合高效處理二進制數據,但需謹慎管理字節切片和長度。

“字節”包裝封裝becapeitoffersefficerSoperationsOnbyteslices,cocialforbinarydatahandling,textPrococessing,andnetworkCommunications.byteslesalemutable,允許forforforforforformance-enhangingin-enhangingin-placemodifications,makaythisspackage

go'sstringspackageIncludeSessentialFunctionsLikeContains,trimspace,split,andreplaceAll.1)contunsefefitedsseffitedsfificeCheckSforSubStrings.2)trimspaceRemovesWhitespaceToeensuredity.3)splitparsentertparsentertparsentertparsentertparstructedtextlikecsv.4)report textlikecsv.4)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

WebStorm Mac版
好用的JavaScript開發工具