gin框架中图形验证码的生成和验证

功能和验证码使用原理

  • 本案例中没有使用redis作为缓存,而是使用的内存存储方法

github链接地址

  • 下载命令
    go get github.com/mojocn/base64Captcha

请求处理函数

// 生成图片验证码
func (m *MemberController) captcha(context *gin.Context) {
	// 生成图片验证码,并返回给客户端
	tool.GenerateCaptcha(context)
}
// 校验图片验证码
func (m *MemberController) verifyCaptcha(context *gin.Context) {
	var captchaResult tool.CaptchaResult
	err := tool.Decode(context.Request.Body, &captchaResult)  // 等价于:context.ShouldBind(&captchaResult)
	if err != nil {
		tool.Failed(context, "参数解析失败")
	}

	// 获取图片验证码的id和b64s,并校验
	result := tool.VerifyCaptcha(captchaResult.Id, captchaResult.VerifyValue)
	if result {
		fmt.Println("图片验证码校验成功")
		tool.Success(context, "校验成功")
	} else {
		fmt.Println("图片验证码校验失败")
		tool.Failed(context, "校验失败")
	}
}

tool.captcha.go

package tool

import (
	"fmt"
	"github.com/gin-gonic/gin"
	"github.com/mojocn/base64Captcha"
)

type CaptchaResult struct {
	Id          string `json:"id"`
	Base64Blog  string `json:"base_64_blog"`
	VerifyValue string `json:"code"`
}

// 默认存储10240个验证码,每个验证码10分钟过期
var store = base64Captcha.DefaultMemStore

// 生成图片验证码
func GenerateCaptcha(context *gin.Context) {
	// 生成默认数字
	//driver := base64Captcha.DefaultDriverDigit
	// 此尺寸的调整需要根据网站进行调试,链接:
	// https://captcha.mojotv.cn/
	driver := base64Captcha.NewDriverDigit(70, 130, 4, 0.8, 100)
	// 生成base64图片
	captcha := base64Captcha.NewCaptcha(driver, store)
	// 获取
	id, b64s, err := captcha.Generate()
	if err != nil {
		fmt.Println("Register GetCaptchaPhoto get base64Captcha has err:", err)
	}

	captchaResult := CaptchaResult{Id: id, Base64Blog: b64s}
	Success(context, map[string]interface{}{
		"captcha_result": captchaResult,
	})
}

// 校验图片验证码,并清除内存空间
func VerifyCaptcha(id string, value string) bool {
	// TODO 只要id存在,就会校验并清除,无论校验的值是否成功, 所以同一id只能校验一次
        // 注意:id,b64s是空 也会返回true 需要在加判断
	verifyResult := store.Verify(id, value, true)
	return verifyResult
}

测试图片链接
github链接
中文文档

posted @   专职  阅读(1507)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示