基于go语言实现图片验证码的代码示例

 更新时间:2023年10月06日 08:36:31   作者:勿忘33  
这篇文章主要为大家详细介绍了基于go语言实现图片验证码的代码示例,文中的示例代码简洁易懂,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下

1 验证码虚线的作用以及虚线是如何实现的

验证码的虚线的作用

  • 验证码的虚线的作用:防止AI扫描识别
  • 虚线是如何实现的: 调用了数学包里面的sin,cos

2 使用方法

2.1 安装依赖

go get -u github.com/mojocn/base64Captcha

2.2设置默认内存储存器

// 库中提供的默认内存存储器。内存存储器用于存储和验证生成的验证码信息。它将验证码的标识符、验证码图片和相关的验证数据存储在内存中。
var stores = base64Captcha.DefaultMemStore

2.3生成验证码方法以及配置文件解析

    var driver base64Captcha.Driver
    var driverString base64Captcha.DriverString
​
    // 配置验证码信息
    captchaConfig := base64Captcha.DriverString{
         // 验证码图片的高度,以像素为单位。
        Height:          60,  
         //验证码图片的宽度,以像素为单位。                                  
        Width:           200, 
         //验证码图片中随机噪点的数量。在这个例子中,值为0表示没有噪点。                                  
        NoiseCount:      0, 
         // 控制显示在验证码图片中的线条的选项。在这个例子中,1: 直线  2: 曲线4: 点线8: 虚线16: 中空直线32: 中空曲线                                    
        ShowLineOptions: 2 | 4,
        //验证码的长度,即验证码中字符的数量。                                 
        Length:          4,      
        //验证码的字符源,用于生成验证码的字符。在这个例子中,使用数字和小写字母作为字符源。                                
        Source:          "1234567890qwertyuioplkjhgfdsazxcvbnm", 
        BgColor: &color.RGBA{
        //验证码图片的背景颜色。在这个例子中,使用RGBA颜色模型,R表示红色分量,G表示绿色分量,B表示蓝色分量,A表示透明度。
            R: 3,
            G: 102,
            B: 214,
            A: 125,
        },
        //用于绘制验证码文本的字体文件。在这个例子中,使用名为"wqy-microhei.ttc"的字体文件。
        Fonts: []string{"wqy-microhei.ttc"}, 
    }
​
    driverString = captchaConfig
    //将driverString中指定的字体文件转换为驱动程序所需的字体格式,并将结果赋值给driver变量。这个步骤是为了将字体文件转换为正确的格式,以便在生成验证码时使用正确的字体。
    driver = driverString.ConvertFonts()
    //使用driver和stores参数创建一个新的验证码实例,并将其赋值给captcha变量。这里的stores参数表示验证码存储器,用于存储和验证验证码。
    captcha := base64Captcha.NewCaptcha(driver, stores)
    //调用captcha实例的Generate方法生成验证码。lid是生成的验证码的唯一标识符,lb64s是生成的验证码图片的Base64编码字符串,lerr是生成过程中的任何错误。
    lid, lb64s, lerr := captcha.Generate()
    // 从验证码存储器中获取验证码的值
    code = stores.Get(lid, true)
    return lid, lb64s, code, lerr

3 内容解析

3.1 声明驱动的含义

var driver base64Captcha.Driver点进源码里面只有两个主要部分

  • func (d Driver) DrawCaptcha(content string) (item Item, err error)
  • DrawCaptcha 绘制二进制验证码,接收一个 content 参数,用于生成并绘制验证码。它返回一个 Item 结构体和可能的错误。Item 结构体包含了绘制的验证码图像或其他相关信息。
//item结构体源码如下
type Item interface {
    //WriteTo writes to a writer
    WriteTo(w io.Writer) (n int64, err error)
    //EncodeB64string encodes as base64 string
    EncodeB64string() string
}
  • GenerateIdQuestionAnswer 生成随机的id、问题和答案
  • 问题字符串 q 是指用于展示给用户的验证码问题或提示,通常是一个文字描述或短语,要求用户根据该问题来完成验证码的验证。
  • 答案字符串 a 是用户对于验证码问题的回答或响应。用户需要根据展示给他们的问题,在输入框中填写或选择正确的答案。 -func (d Driver) GenerateIdQuestionAnswer() (id, q, a string)

3.2配置使用以及源码解析

  • driverString = captchaConfig这个只是将上述的配置信息传赋值给声明的配置信息
  • driver = driverString.ConvertFonts()这个在上面已经说过他的简单介绍,源码如下
func (d *DriverString) ConvertFonts() *DriverString {
    //是否为 nil。如果是,它将 DefaultEmbeddedFonts 赋值给 d.fontsStorage。否则返回一个使用其默认字体
    if d.fontsStorage == nil {
        d.fontsStorage = DefaultEmbeddedFonts
    }
    //代码创建了一个空的切片 tfs,用于存储字体文件。然后它遍历 d.Fonts 切片中的每个元素,并通过
    // d.fontsStorage.LoadFontByName 方法加载对应的字体文件。加载的字体文件会被追加到 tfs 切片中。
    tfs := []*truetype.Font{}
    for _, fff := range d.Fonts {
        tf := d.fontsStorage.LoadFontByName("fonts/" + fff)
        tfs = append(tfs, tf)
    }
    //代码创建了一个空的切片 tfs,用于存储字体文件。然后它遍历 d.Fonts 切片中的每个元素,
    //并通过 d.fontsStorage.LoadFontByName 方法加载对应的字体文件。加载的字体文件会被追加到 tfs 切片中。这意味着如果没有加载任何字体文件,它将使用 fontsAll 中的默认字体。
    if len(tfs) == 0 {
        tfs = fontsAll
    }
    //这行代码将刚刚生成的字体切片 tfs 赋值给 d.fontsArray,将其存储在 DriverString 结构体中。
    d.fontsArray = tfs
​
    return d
}
  • captcha := base64Captcha.NewCaptcha(driver, stores)
func NewCaptcha(driver Driver, store Store) *Captcha {
    //这行代码创建了一个 Captcha 结构体的实例,并使用传入的 driver 和 store 参数初始化了 Driver 和 Store 字段。
    return &Captcha{Driver: driver, Store: store}
}
  • lid, lb64s, lerr := captcha.Generate()
func (c *Captcha) Generate() (id, b64s string, err error) {
    id, content, answer := c.Driver.GenerateIdQuestionAnswer()
    //这里调用的就是上面介绍第一个声明的验证码的生成方法
    item, err := c.Driver.DrawCaptcha(content)
    //根据验证码的内容 content 生成验证码图像,并返回生成的图像,也是上面介绍的第一个声明的一部分
    if err != nil {
        return "", "", err
    }
    err = c.Store.Set(id, answer)
    //将验证码的标识符 id 和正确答案 answer 存储在声明的默认内存存储器中。
    if err != nil {
        return "", "", err
    }
    b64s = item.EncodeB64string()
    // item 的 EncodeB64string 方法,将生成的验证码图像转换为 Base64 字符串表示。(个人理解图片在传递过程中是以二进制的形式传递的,通过这个方法将其转化为Base64编码的形式)
    //Base64 是一种常用的编码方式,用于将二进制数据转换成可打印的 ASCII 字符串。Base64 编码通常用于在文本协议中传输二进制数据,或者在需要将二进制数据表示为字符串时使用。
    return
}
  • code = stores.Get(lid, flase)涉及到默认内存存储器直接就在这里简单说明了
type Store interface {
    //这个方法就是上面生成验证码时,向默认内存存储器储存数据
    Set(id string, value string) error
    //获取通过生成验证码的id获取默认内存存储器中存储的数据
    //第二个参数:true会返回与指定的验证码数据项相关的其他信息。这些信息可能包括验证码生成时间、过期时间、元数据或其他属性。false返回指定验证码数据项本身,而不包含与其相关的其他信息
    Get(id string, clear bool) string
    //第一个参数是验证码的唯一表示即判断是否是当前验证码   第二个参数是用户输入的验证码  第三个参数是是否开启大小写映射,即验证时是否忽略大小写,这个包直接就给我们封装了校验验证码
    Verify(id, answer string, clear bool) bool
}

4 代码实例

import (
    "fmt"
    "github.com/mojocn/base64Captcha"
    "image/color"
)
var stores = base64Captcha.DefaultMemStore
func CaptMake() (id, b64s string, code string, err error) {
    var driver base64Captcha.Driver
    var driverString base64Captcha.DriverString
​
    // 配置验证码信息
    captchaConfig := base64Captcha.DriverString{
        Height:          60,                                    
        Width:           200,                                    
        NoiseCount:      0,                                      
        ShowLineOptions: 2 | 4,                                 
        Length:          4,                                      
        Source:          "1234567890qwertyuioplkjhgfdsazxcvbnm",
        BgColor: &color.RGBA{
            R: 3,
            G: 102,
            B: 214,
            A: 125,
        },
        Fonts: []string{"wqy-microhei.ttc"},
    }
​
    driverString = captchaConfig
    driver = driverString.ConvertFonts()
    captcha := base64Captcha.NewCaptcha(driver, stores)
    lid, lb64s, lerr := captcha.Generate()
    code = stores.Get(lid, true)
    fmt.Println(code)
    return lid, lb64s, code, lerr
}
//这个解析方式只是上面介绍的内存存储器的方法调用,使用起来看情况是否使用
func CaptVerify(id string, capt string) bool {
    if stores.Verify(id, capt, false) {
        return true
    } else {
        return false
    }
}

到此这篇关于基于go语言实现图片验证码的代码示例的文章就介绍到这了,更多相关go实现图片验证码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言结构化日志slog的用法解析

    Go语言结构化日志slog的用法解析

    go 1.21.0 版本引入了一个新的包 log/slog,该包提供了结构化日志的功能,本文小编就来和大家聊聊log/slog 包的使用,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-10-10
  • golang使用iconv报undefined:XXX的问题处理方案

    golang使用iconv报undefined:XXX的问题处理方案

    这篇文章主要介绍了golang使用iconv报undefined:XXX的问题处理方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Go语言编程中字符串切割方法小结

    Go语言编程中字符串切割方法小结

    这篇文章主要介绍了Go语言编程中字符串切割方法小结,所整理的方法都来自字符串相关的strings包,需要的朋友可以参考下
    2015-10-10
  • Go使用协程批量获取数据加快接口返回速度

    Go使用协程批量获取数据加快接口返回速度

    这篇文章主要介绍了Go使用协程批量获取数据加快接口返回速度,使用Go语言后,可以并发获取,极大提升效率,需要的朋友可以参考下
    2023-02-02
  • Go语言中io包核心接口示例详解

    Go语言中io包核心接口示例详解

    Go的io包提供了io.Reader和io.Writer接口,分别用于数据的输入和输出,下面这篇文章主要给大家介绍了关于Go语言中io包核心接口的相关资料,需要的朋友可以参考下
    2021-12-12
  • 详解如何在Go中如何编写出可测试的代码

    详解如何在Go中如何编写出可测试的代码

    在编写测试代码之前,还有一个很重要的点,容易被忽略,就是什么样的代码是可测试的代码,所以本文就来聊一聊在 Go 中如何写出可测试的代码吧
    2023-08-08
  • go语言中的map如何解决散列性能下降

    go语言中的map如何解决散列性能下降

    近期对go语言的map进行深入了解和探究,其中关于map解决大量冲突的扩容操作设计的十分巧妙,所以笔者特地整理了这篇文章来探讨一下go语言中map如何解决散列性能下降,文中有相关的代码示例供大家参考,需要的朋友可以参考下
    2024-03-03
  • Go Fiber快速搭建一个HTTP服务器

    Go Fiber快速搭建一个HTTP服务器

    Fiber 是一个 Express 启发 web 框架基于 fasthttp ,最快 Go 的 http 引擎,这篇文章主要介绍了Go Fiber快速搭建一个HTTP服务器,需要的朋友可以参考下
    2023-06-06
  • Golang交叉编译之跨平台编译使用详解

    Golang交叉编译之跨平台编译使用详解

    这篇文章主要为大家介绍了Golang交叉编译之跨平台编译使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Golang异常处理之defer,panic,recover的使用详解

    Golang异常处理之defer,panic,recover的使用详解

    这篇文章主要为大家介绍了Go语言异常处理机制中defer、panic和recover三者的使用方法,文中示例代码讲解详细,需要的朋友可以参考下
    2022-05-05

最新评论