当前位置: 首页 > news >正文

挑战视觉边界,探索图形验证码背后的黑科技

在日常生活中,我们登录网站或者其他平台时,在填写完账号密码之后,还会让我们填写4或6位的数字或者英文字母等,填写正确才能请求登录。这个其实是防止某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试,如下图所示:

在这里插入图片描述

EasyCaptcha简介

现在,我们知道登录的时候需要填写验证码的原因,但图形验证码从何得来,是怎么生成的呢,这就需要我们去探索了。当然现在开源代码比较多,我这里推荐的就是一个开源的图形验证码,样式挺好看、类型也很多。

EasyCaptcha源码地址:https://gitee.com/ele-admin/EasyCaptcha

Java图形验证码,支持gif、中文、算术等类型,可用于Java Web、JavaSE等项目。

在这里插入图片描述

引入EasyCaptcha依赖

在IDEA中新建一个SpringBoot项目,版本为2.0以上的即可,在pom.xml中添加easycaptcha依赖,代码如下:

<!-- 图形验证码 -->
<dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>18.0</version>
</dependency><dependency><groupId>com.github.whvcse</groupId><artifactId>easy-captcha</artifactId><version>1.6.2</version>
</dependency>

在项目中新建一个VerificationCode类,用来设置验证码图片的属性,包括宽度、高度、位数等操作。,代码如下:

    /*** 生成验证码图片的宽度*/private int width = 100;/*** 生成验证码图片的高度*/private int height = 30;/*** 生成验证码的位数*/private int digit = 4;/*** 生成的验证码code*/private String captchaCode;

接着在该类中新建一个生成验证码图形的方法。

    /*** 生成验证码** @return*/
public SpecCaptcha createVerificationCode() throws IOException, FontFormatException {// 三个参数分别为宽、高、位数SpecCaptcha specCaptcha = new SpecCaptcha(width, height, digit);// 设置字体specCaptcha.setFont(Captcha.FONT_9);// 设置类型,纯数字、纯字母、字母数字混合specCaptcha.setCharType(Captcha.TYPE_ONLY_NUMBER);// 验证码this.captchaCode = specCaptcha.text().toLowerCase();return specCaptcha;
}

我这里选择的是纯数字的类型,字体为FONT_9,在项目中可根据自己的需要进行修改。

接下来,写一个生成验证码的接口,将我们后端生成的数字以图片的格式返给前端展示。新建一个controller包,然后创建一个LoginController类。在该类中创建一个生成验证码的方法,并把图片以base64的格式输出,代码如下:

    @GetMapping("/captcha")public void getVerifyCode(HttpServletResponse response) throws IOException, FontFormatException {try {// 设置请求头为输出图片类型VerificationCode code = new VerificationCode();SpecCaptcha specCaptcha = code.createVerificationCode();// 创建字节数组输出流ByteArrayOutputStream baos = new ByteArrayOutputStream();// 将验证码图片输出到字节数组输出流中specCaptcha.out(baos);// 将字节数组转换为 Base64 编码byte[] imageBytes = baos.toByteArray();InputStream inStream = new ByteArrayInputStream(imageBytes);OutputStream outputStream = null;outputStream = new BufferedOutputStream(response.getOutputStream());//创建存放文件内容的数组byte[] buff = new byte[1024];//所读取的内容使用n来接收int n;//当没有读取完时,继续读取,循环while ((n = inStream.read(buff)) != -1) {//将字节数组的数据全部写入到输出流中outputStream.write(buff, 0, n);}//强制将缓存区的数据进行输出outputStream.flush();//关流outputStream.close();inStream.close();} catch (IOException e) {e.printStackTrace();}}

接下来,启动项目,然后在浏览器中,访问:http://localhost:8080/captcha地址,则就可以获取到图形验证码的图片。

在这里插入图片描述

http://www.lryc.cn/news/234593.html

相关文章:

  • 【网络奇缘】- 计算机网络|网络类型|性能指标
  • Leetcode—剑指Offer LCR 140.训练计划II【简单】
  • 梦想编织者——Adobe Dreamweaver
  • springMVC学习笔记-请求映射,参数绑定,响应,restful,响应状态码,springMVC拦截器
  • Python实现视频字幕时间轴格式转换
  • 蓝桥杯 枚举
  • C#的MessagePack(unity)--02
  • MySQL数据库管理--- mysql数据库迁移-v查看报错sql
  • 基于秃鹰算法优化概率神经网络PNN的分类预测 - 附代码
  • 向pycdc项目提的一个pr
  • Spring学习③__Bean管理
  • 《视觉SLAM十四讲》-- 后端 2
  • 安装插件时Vscode XHR Failed 报错ERR_CERT_AUTHORITY_INVALID
  • ON_WM_TIMER()
  • 【Unity】单例模式及游戏声音管理类应用
  • 视频剪辑技巧:轻松搞定视频随机合并,一篇文章告知所有秘诀
  • torch.stack
  • 手搓哈希表、列表、队列,只为了用C语言快速求解华容道游戏,我不是大佬,只是一个游戏算法爱好者
  • MySQL 的执行原理(一)
  • 2023_“数维杯”问题B:棉秸秆热解的催化反应-详细解析含代码
  • django理解01
  • 限制Domain Admin登录非域控服务器和用户计算机
  • 原来机械硬盘比内存慢10万倍
  • ElementUI的Dialog弹窗实现拖拽移动功能
  • 生成式AI模型量化简明教程
  • 机器人制作开源方案 | 智能快递付件机器人
  • PostgreSQL技术大讲堂 - 第34讲:调优工具pgBagder部署
  • 《Python日志新宠——Loguru,轻松记录,笑对Bug!》
  • NET8 ORM 使用AOT SqlSugar
  • CCRC认证是什么?