前言:
这段时间需要使用图片验证码库,最近网上使用教程都有点旧了,base64Captcha库的example也有点问题,在这里整体一下使用方法,与官方demo中的bug。
图像验证码库
github.com/mojocn/base64Captcha
使用
先开辟一个验证码使用的存储空间
var store = base64Captcha.DefaultMemStore
// base64Captcha.DefaultMemStore是默认的:10240 个 过期时间10分钟
// 也可以自己设定参数base64Captcha.NewMemoryStore(GCLimitNumber, Expiration)
创建验证码驱动
分为5种不同类型的图形验证码
- dight 数字验证码
- audio 语音验证码
- string 字符验证码
- math 数学验证码(加减乘除)
- 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 开发可以试下将库的源码调整下位置 就可以使用了。