主页 > 软件开发  > 

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

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

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

一、加入依赖

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

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

[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的纯色图片。

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

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

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

let img2 = RgbImage::from_pixel(20, 25, Rgb([226,226,240])); img2.save("A.jpg").expect("jpg save failed"); 三、编辑验证图片

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

四,随机函数编写

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

fn ge_code_char()-> char{ let mut rng = rand::rng(); let s = "ABCDEFGHJKLMNPRSTUVWXYZ0123456789"; s.chars().choose(&mut rng).unwrap() } 五,生成验证码图片

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

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"); }

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

    第一次:

    第二次:

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

标签:

如何通过rust实现自己的web登录图片验证码由讯客互联软件开发栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“如何通过rust实现自己的web登录图片验证码