Go語言簡易圖像驗(yàn)證碼生成的實(shí)戰(zhàn)案例
在 Web 應(yīng)用中,驗(yàn)證碼(CAPTCHA)常用于防止機(jī)器人批量提交請求,比如注冊、登錄、評論等功能。 本篇我們將使用 Go 語言和 Gin 框架,結(jié)合第三方庫 github.com/mojocn/base64Captcha,快速實(shí)現(xiàn)一個簡易圖像驗(yàn)證碼生成接口。
一、功能目標(biāo)
- 提供一個生成驗(yàn)證碼的 API,返回驗(yàn)證碼圖片(Base64 編碼)和驗(yàn)證碼 ID。
- 前端展示驗(yàn)證碼圖片,并在提交時攜帶驗(yàn)證碼 ID 和用戶輸入。
- 提供一個校驗(yàn)驗(yàn)證碼的 API。
二、安裝依賴
首先安裝 Gin 和 Base64Captcha:
go get github.com/gin-gonic/gin go get github.com/mojocn/base64Captcha
三、代碼實(shí)現(xiàn)
package main
import (
"github.com/gin-gonic/gin"
"github.com/mojocn/base64Captcha"
"net/http"
)
// 驗(yàn)證碼存儲在內(nèi)存中(也可以換成 Redis)
var store = base64Captcha.DefaultMemStore
// 生成驗(yàn)證碼
func generateCaptcha(c *gin.Context) {
driver := base64Captcha.NewDriverDigit(80, 240, 5, 0.7, 80) // 高度80, 寬度240, 5位數(shù)字
captcha := base64Captcha.NewCaptcha(driver, store)
id, b64s, err := captcha.Generate()
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": "驗(yàn)證碼生成失敗"})
return
}
c.JSON(http.StatusOK, gin.H{
"captcha_id": id,
"captcha_image": b64s, // Base64 編碼的圖片
})
}
// 校驗(yàn)驗(yàn)證碼
func verifyCaptcha(c *gin.Context) {
var req struct {
ID string `json:"id"`
Value string `json:"value"`
}
if err := c.ShouldBindJSON(&req); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
return
}
if store.Verify(req.ID, req.Value, true) { // true 表示驗(yàn)證成功后清除
c.JSON(http.StatusOK, gin.H{"message": "驗(yàn)證成功"})
} else {
c.JSON(http.StatusBadRequest, gin.H{"message": "驗(yàn)證碼錯誤"})
}
}
func main() {
r := gin.Default()
r.GET("/captcha", generateCaptcha)
r.POST("/verify", verifyCaptcha)
r.Run(":8080")
}
四、運(yùn)行與測試
運(yùn)行服務(wù):
go run main.go
1. 獲取驗(yàn)證碼
curl http://localhost:8080/captcha
返回:
{
"captcha_id": "ZffX7Xr7EccGdS4b",
"captcha_image": "data:image/png;base64,iVBORw0KGgoAAAANSUhE..."
}
前端可直接用 <img src="captcha_image" /> 渲染驗(yàn)證碼。
2. 校驗(yàn)驗(yàn)證碼
curl -X POST http://localhost:8080/verify \
-H "Content-Type: application/json" \
-d '{"id":"ZffX7Xr7EccGdS4b","value":"12345"}'
五、注意事項(xiàng)
驗(yàn)證碼存儲
- 本示例使用內(nèi)存存儲,適合單機(jī)開發(fā)環(huán)境。
- 生產(chǎn)環(huán)境建議使用 Redis 等共享存儲。
驗(yàn)證碼類型
base64Captcha支持?jǐn)?shù)字、字母混合、中文等類型,可以根據(jù)業(yè)務(wù)需求選擇不同Driver。安全性
- 不能把驗(yàn)證碼 ID 暴露給爬蟲(可配合 CSRF、限流等手段)。
- 驗(yàn)證碼要有有效期,防止重放攻擊。
六、總結(jié)
使用 base64Captcha 結(jié)合 Gin,可以非常方便地生成和校驗(yàn)驗(yàn)證碼。 本篇示例已經(jīng)可以直接應(yīng)用到注冊、登錄等防刷場景中。
到此這篇關(guān)于Go語言簡易圖像驗(yàn)證碼生成的實(shí)戰(zhàn)案例的文章就介紹到這了,更多相關(guān)Go語言圖像驗(yàn)證碼生成內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang 實(shí)現(xiàn)Socket服務(wù)端和客戶端使用TCP協(xié)議通訊
這篇文章主要介紹了Golang 實(shí)現(xiàn)Socket服務(wù)端和客戶端使用TCP協(xié)議通訊,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
Go?1.21新內(nèi)置函數(shù)min、max和clear的用法詳解
Go?1.21?版本已經(jīng)正式發(fā)布,它帶來了許多新特性和改進(jìn),其中引入了的三個新內(nèi)置函數(shù):max、min?和?clear,接下來我們就來看看這些函數(shù)的用途和特點(diǎn)吧2023-08-08
Golang設(shè)計(jì)模式中抽象工廠模式詳細(xì)講解
抽象工廠模式用于生成產(chǎn)品族的工廠,所生成的對象是有關(guān)聯(lián)的。如果抽象工廠退化成生成的對象無關(guān)聯(lián)則成為工廠函數(shù)模式。比如本例子中使用RDB和XML存儲訂單信息,抽象工廠分別能生成相關(guān)的主訂單信息和訂單詳情信息2023-01-01

