当前位置: 首页 > news >正文

Go语言实战案例:简易图像验证码生成

在 Web 应用中,验证码(CAPTCHA)常用于防止机器人批量提交请求,比如注册、登录、评论等功能。
本篇我们将使用 Go 语言和 Gin 框架,结合第三方库 github.com/mojocn/base64Captcha,快速实现一个简易图像验证码生成接口


一、功能目标

  1. 1. 提供一个生成验证码的 API,返回验证码图片(Base64 编码)和验证码 ID。
  2. 2. 前端展示验证码图片,并在提交时携带验证码 ID 和用户输入。
  3. 3. 提供一个校验验证码的 API。

二、安装依赖

首先安装 Gin 和 Base64Captcha:

go get github.com/gin-gonic/gin
go get github.com/mojocn/base64Captcha

三、代码实现

package mainimport ("github.com/gin-gonic/gin""github.com/mojocn/base64Captcha""net/http"
)// 验证码存储在内存中(也可以换成 Redis)
var store = base64Captcha.DefaultMemStore// 生成验证码
func generateCaptcha(c *gin.Context) {driver := base64Captcha.NewDriverDigit(80, 240, 5, 0.7, 80) // 高度80, 宽度240, 5位数字captcha := base64Captcha.NewCaptcha(driver, store)id, b64s, err := captcha.Generate()if err != nil {c.JSON(http.StatusInternalServerError, gin.H{"error": "验证码生成失败"})return}c.JSON(http.StatusOK, gin.H{"captcha_id":   id,"captcha_image": b64s, // Base64 编码的图片})
}// 校验验证码
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 表示验证成功后清除c.JSON(http.StatusOK, gin.H{"message": "验证成功"})} else {c.JSON(http.StatusBadRequest, gin.H{"message": "验证码错误"})}
}func main() {r := gin.Default()r.GET("/captcha", generateCaptcha)r.POST("/verify", verifyCaptcha)r.Run(":8080")
}

四、运行与测试

运行服务:

go run main.go

1. 获取验证码

curl http://localhost:8080/captcha

返回:

{"captcha_id": "ZffX7Xr7EccGdS4b","captcha_image": "data:image/png;base64,iVBORw0KGgoAAAANSUhE..."
}

前端可直接用 <img src="captcha_image" /> 渲染验证码。


2. 校验验证码

curl -X POST http://localhost:8080/verify \-H "Content-Type: application/json" \-d '{"id":"ZffX7Xr7EccGdS4b","value":"12345"}'

五、注意事项

  1. 1. 验证码存储
    • • 本示例使用内存存储,适合单机开发环境。
    • • 生产环境建议使用 Redis 等共享存储。
  2. 2. 验证码类型
    base64Captcha 支持数字、字母混合、中文等类型,可以根据业务需求选择不同 Driver
  3. 3. 安全性
    • • 不能把验证码 ID 暴露给爬虫(可配合 CSRF、限流等手段)。
    • • 验证码要有有效期,防止重放攻击。

六、总结

使用 base64Captcha 结合 Gin,可以非常方便地生成和校验验证码。
本篇示例已经可以直接应用到注册、登录等防刷场景中。


http://www.xdnf.cn/news/1297279.html

相关文章:

  • Java 设计模式-组合模式
  • Vscode的wsl环境开发ESP32S3的一些问题总结
  • 在 Windows 系统中解决 Git 推送时出现的 Permission denied (publickey) 错误,请按照以下详细步骤操作:
  • 宋红康 JVM 笔记 Day01|JVM介绍
  • [工具]vscode 使用AI 优化代码
  • 使用EvalScope对GPT-OSS-20B进行推理性能压测实战
  • 【完整源码+数据集+部署教程】肾脏病变实例分割系统源码和数据集:改进yolo11-CARAFE
  • 自动化运维实验(二)---自动识别设备,并导出配置
  • AM32电调学习-使用Keil编译uboot
  • 搭建局域网yum源仓库全流程
  • 华为实验 链路聚合
  • GoLand 项目从 0 到 1:第八天 ——GORM 命名策略陷阱与 Go 项目启动慢问题攻坚
  • 更新pip及Python软件包的完整指南
  • STM32HAL 快速入门(七):GPIO 输入之光敏传感器控制蜂鸣器
  • 第3节 深度学习避坑指南:从过拟合到玄学优化
  • 92、23种设计模式-单例模式
  • 【软考架构】信息安全基础知识
  • 考研408《计算机组成原理》复习笔记,第五章(1)——CPU功能和结构
  • 云原生存储架构设计与性能优化
  • 【深度学习计算性能】04:硬件
  • CTFSHOW | nodejs题解 web334 - web344
  • 主进程如何将客户端连接分配到房间进程
  • 数巅中标中建科技AI知识库项目,开启建筑业数智化新篇章
  • 项目日志框架与jar中日志框架冲突 解决
  • MFC的使用——使用ChartCtrl绘制曲线
  • DataHub IoT Gateway:工业现场设备与云端平台安全互联的高效解决方案
  • 使用HalconDotNet实现异步多相机采集与实时处理
  • 零信任架构(Zero Trust Architecture, ZTA)(通过动态验证和最小权限控制,实现对所有访问请求的严格授权和持续监控)
  • Kafka消费者组
  • OpenCV阈值处理详解