前言:

这段时间需要使用图片验证码库,最近网上使用教程都有点旧了,base64Captcha库的example也有点问题,在这里整体一下使用方法,与官方demo中的bug。

图像验证码库

github.com/mojocn/base64Captcha

使用

先开辟一个验证码使用的存储空间

var store = base64Captcha.DefaultMemStore
// base64Captcha.DefaultMemStore是默认的:10240 个 过期时间10分钟
// 也可以自己设定参数base64Captcha.NewMemoryStore(GCLimitNumber, Expiration)

创建验证码驱动
分为5种不同类型的图形验证码

  1. dight 数字验证码
  2. audio 语音验证码
  3. string 字符验证码
  4. math 数学验证码(加减乘除)
  5. chinese中文验证码-有bug
// 生成默认数字的driver
driver := base64Captcha.DefaultDriverDigit
// 也可以自定义参数
base64Captcha.NewDriverDigit(height , width , length , maxSkew , dotCount)

每种类型都可以生成自定义参数的图片验证码

注:不同参数是什么效果可以根据这个选择 https://captcha.mojotv.cn/

生成验证码,同时保存至store

c := base64Captcha.NewCaptcha(driver, store)

生成base64图像验证及id

id, b64s, err := c.Generate()

验证正确

store.Verify(id, b64s, true) 

注意:id,b64s是空 也会返回true 需要在加判断

整体使用demo

package main

import (
	"fmt"
	"github.com/mojocn/base64Captcha"
)

var store = base64Captcha.DefaultMemStore

func main(){
	id,b64s := GetCaptcha()
	// 中间可以发给客户端,让他输入然后你来验证
	Verify(id,b64s)
}

//  获取验证码
func GetCaptcha()(string, string){
	// 生成默认数字
	driver := base64Captcha.DefaultDriverDigit
	// 生成base64图片
	c := base64Captcha.NewCaptcha(driver, store)

	// 获取
	id, b64s, err := c.Generate()
	if err != nil {
		fmt.Println("Register GetCaptchaPhoto get base64Captcha has err:", err)
		return "",""
	}
	return id, b64s
}

// 验证验证码
func Verify(id string, val string) bool {
	if id == "" || val == ""{
		return false
	}
	// 同时在内存清理掉这个图片
	return store.Verify(id, val, true)
}

关于官方demo的bug

根据官方demo获取的验证码会报恐慌
在这里插入图片描述
追一下源码
在这里插入图片描述
如图可知:
fontChinese定义在了后面,没有被放入fontsAll数组里面
因此不要使用 XX.ConvertFonts() 或者 使用中文字体 获取驱动即可
当然你没用 gomod 开发可以试下将库的源码调整下位置 就可以使用了。