如何通过rust实现自己的web登录图片验证码

在进行web系统开发时,为保障系统登录安全,登录页面中的验证码必不可少。在java中,我们可以利用相应的2D图像库快速生成图形验证码,而对于rust,我们没有合适的标准库进行图像验证码的生成。今天,我们通过使用image crate,通过rust生成图像验证码。

一、加入依赖

我们通过cargo,在我们的项目中引入image依赖。

我们查看项目中的Cargo.toml文件,可以看到我们加入了image crate依赖。

rust 复制代码
[package]
name = "app-web1"
version = "0.1.0"
edition = "2021"

[dependencies]
actix-files = "0.6.6"
actix-web = "4.9.0"
captcha = "0.0.9"
image = "0.25.5"
oracle = "0.6.3"
rand = "0.9.0"
serde = "1.0.218"

二、生成纯色图片

通过代码生成一个长80,高25的纯色图片。

rust 复制代码
    let img2 = RgbImage::from_pixel(80, 25, Rgb([226,226,240]));
    
    img2.save("codeimage.jpg").expect("jpg save failed");

我们查看生成的图片信息:

我们再通过代码生成四分之一长,高度也为25的纯色图片,用来存储我们的验证字母和数字。

rust 复制代码
    let img2 = RgbImage::from_pixel(20, 25, Rgb([226,226,240]));
    
    img2.save("A.jpg").expect("jpg save failed");

三、编辑验证图片

通过翻阅image crate的依赖库,尚未发现直接在图片中写入文字的方法,故本人通过手工添加26个字符和10个数字的方式,完成随机字母和数字图片的编辑。

四,随机函数编写

我们通过编写一个随机获取我们指定字符的函数,为后续随机生成验证图片提供支持。

rust 复制代码
fn ge_code_char()-> char{
    let mut rng = rand::rng();
    let s = "ABCDEFGHJKLMNPRSTUVWXYZ0123456789";
    s.chars().choose(&mut rng).unwrap()
}

五,生成验证码图片

我们通过循环获取验证字符,并通过拼接字符图片到我们的验证码图片,最终生成我们需要的验证码图片。

rust 复制代码
pub fn ge_code_img(){
    //生成一个宽度为70,高为25的颜色为Rgb([226,226,240]的图像,并保存为文件
    let mut img2 = RgbImage::from_pixel(80, 25, Rgb([226,226,240]));
    for i in 0..4{
        let c = ge_code_char();
        let cp = c.to_string()+".jpg";
        let img3 = ImageReader::open(cp).expect("open A.jpg failed").decode().expect("decode failed");
        img2.copy_from(&(img3.to_rgb8()), i*20, 0).expect("copy from sub img failed!");
    }
    img2.save("codeimage.jpg").expect("jpg save failed");
}

我们运行函数,验证随机验证码图片是否生成:

第一次:

第二次:

至此,我们的图片验证码程序完成!

相关推荐
花褪残红青杏小20 小时前
Rust图像处理第9节-Sobel 边缘检测:第一个真正用卷积的算法
rust·webassembly·图形学
doiito1 天前
【Agent Harness】Gliding Horse L2 作战地图深度优化:给多 Agent 上下文装上“精准导航”
ai·rust·架构设计·系统设计·ai agent
花褪残红青杏小1 天前
Rust图像处理第8节-暗角 & 复古胶片特效:四周衰减中心高亮
rust·webassembly·图形学
独孤留白2 天前
从C到Rust:Rust 的 Trait 不是Interface,那是什么?
rust
花褪残红青杏小2 天前
Rust图像处理第7节-马赛克像素化:分块取平均色实现打码风格
rust·webassembly·图形学
doiito3 天前
【Agent Harness】Gliding Horse 设计细节 -- 不跟风开发自己的AI Agent
架构·rust·agent
doiito3 天前
【Agent Harness】Gliding Horse 核心设计理念,不跟风开发自己的AI Agent
ai·rust·架构设计·系统设计·ai agent
花褪残红青杏小3 天前
Rust图像处理第6节- 均值模糊 & 中值模糊:3×3 邻域的两种经典玩法
rust·webassembly·图形学
子兮曰4 天前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust