接口防刷:图形验证码

2024-04-12 16:28
文章标签 接口 图形 验证码 防刷

本文主要是介绍接口防刷:图形验证码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

一、背景介绍

二、设计思路

三、核心代码展示

总结


提示:以下是本篇文章正文内容,下面案例可供参考

一、背景介绍

重置密码,会给用户手机号发送一个短信验证码,因为该接口是未登录就可以访问,所以存在防刷风险。还会遇到未申请重置密码的用户,收到了重置密码的短信。

二、设计思路

1、通过用户有效性,能拦截大部分用户不存在的请求,但是会对已存在的用户,发送短信。

2、针对上边这种解决方案,查漏补缺,不能让请求直接穿透我们的逻辑。此时,图形验证码就登场了。

首先,这个东西是免费的,我们可以后台生成一个图形验证码,并返回给前端进行展示,真实的图形验证码存放在缓存中,并设置过期时间。

其次,每次提交的时候,先用手机号校验一层,验证该手机号当前是否有生效中的图形验证码,如果有,继续向下。如果没有,返回提示。

最后,当有生效的图形验证码存在时,校验前端传递的验证码值和缓存中的是否一致。不一致返回提示,一致的话,向下执行核心逻辑,发送短信验证码。

如果出现图形验证码被攻破的场景,我们只需要变换图形验证码的难易程度和复杂度,即可快速升级防刷级别。

三、核心代码展示

1、生成图形验证码的代码示例

public String generateCaptcha() {// 创建空白图像BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);Graphics graphics = image.getGraphics();// 设置背景色graphics.setColor(Color.WHITE);graphics.fillRect(0, 0, WIDTH, HEIGHT);// 绘制随机字符Random random = new Random();StringBuilder captcha = new StringBuilder();for (int i = 0; i < CHAR_NUM; i++) {char c = (char) (random.nextInt(26) + 'A'); // 生成随机大写字母captcha.append(c);graphics.setFont(new Font("Arial", Font.BOLD, FONT_SIZE));graphics.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255)));graphics.drawString(String.valueOf(c), i * (WIDTH / CHAR_NUM) + 20, HEIGHT / 2);}// 添加干扰线和噪点graphics.setColor(Color.GRAY);for (int i = 0; i < 10; i++) {int x1 = random.nextInt(WIDTH);int y1 = random.nextInt(HEIGHT);int x2 = random.nextInt(WIDTH);int y2 = random.nextInt(HEIGHT);graphics.drawLine(x1, y1, x2, y2);}for (int i = 0; i < 100; i++) {int x = random.nextInt(WIDTH);int y = random.nextInt(HEIGHT);graphics.fillOval(x, y, 2, 2);}// 释放资源graphics.dispose();return captcha.toString();
}

2、给前端返回图形验证码,用于展示的代码示例,不一样的地方在于,返回的内容不一样。

    public String generateCaptcha() {// 创建空白图像BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);Graphics graphics = image.getGraphics();// 设置背景色graphics.setColor(Color.WHITE);graphics.fillRect(0, 0, WIDTH, HEIGHT);// 绘制随机字符Random random = new Random();StringBuilder captcha = new StringBuilder();for (int i = 0; i < CHAR_NUM; i++) {char c = (char) (random.nextInt(26) + 'A'); // 生成随机大写字母captcha.append(c);graphics.setFont(new Font("Arial", Font.BOLD, FONT_SIZE));graphics.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255)));graphics.drawString(String.valueOf(c), i * (WIDTH / CHAR_NUM) + 20, HEIGHT / 2);}// 添加干扰线和噪点graphics.setColor(Color.GRAY);for (int i = 0; i < 10; i++) {int x1 = random.nextInt(WIDTH);int y1 = random.nextInt(HEIGHT);int x2 = random.nextInt(WIDTH);int y2 = random.nextInt(HEIGHT);graphics.drawLine(x1, y1, x2, y2);}for (int i = 0; i < 100; i++) {int x = random.nextInt(WIDTH);int y = random.nextInt(HEIGHT);graphics.fillOval(x, y, 2, 2);}// 释放资源graphics.dispose();// 保存图像到文件try {File outputfile = new File("captcha.png");ImageIO.write(image, "png", outputfile);return outputfile.} catch (Exception e) {e.printStackTrace();}return 文件的字节流;
}

获取图形验证码的功能,也不用拘泥于一个手机号新生成一个验证码,这个是对资源的浪费。

我们可以预生成一千个、一万个,然后将其存放于缓存中,直接随机从其中读取即可。

那么有人就会问了,这个如果都是固定的,也会被记忆并攻破,可以每隔一段时间,更新一下验证码的库,这样就能保证我们的库是准实时变化的。


总结

动动脑,能防老!

这篇关于接口防刷:图形验证码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897641

相关文章

SpringBoot实现图形验证码的示例代码

《SpringBoot实现图形验证码的示例代码》验证码的实现方式有很多,可以由前端实现,也可以由后端进行实现,也有很多的插件和工具包可以使用,在这里,我们使用Hutool提供的小工具实现,本文介绍Sp... 目录项目创建前端代码实现约定前后端交互接口需求分析接口定义Hutool工具实现服务器端代码引入依赖获

requests处理token鉴权接口和jsonpath使用方式

《requests处理token鉴权接口和jsonpath使用方式》文章介绍了如何使用requests库进行token鉴权接口的处理,包括登录提取token并保存,还详述了如何使用jsonpath表达... 目录requests处理token鉴权接口和jsonpath使用json数据提取工具总结reques

使用Python在PDF中绘制多种图形的操作示例

《使用Python在PDF中绘制多种图形的操作示例》在进行PDF自动化处理时,人们往往首先想到的是文本生成、图片嵌入或表格绘制等常规需求,然而在许多实际业务场景中,能够在PDF中灵活绘制图形同样至关重... 目录1. 环境准备2. 创建 PDF 文档与页面3. 在 PDF 中绘制不同类型的图形python

python调用dubbo接口的实现步骤

《python调用dubbo接口的实现步骤》本文主要介绍了python调用dubbo接口的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录 ​​其他实现方式与注意事项​​ ​​高级技巧与集成​​用 python 提供 Dubbo 接口

Java中接口和抽象类的异同以及具体的使用场景

《Java中接口和抽象类的异同以及具体的使用场景》文章主要介绍了Java中接口(Interface)和抽象类(AbstractClass)的区别和联系,包括相同点和不同点,以及它们在实际开发中的具体使... 目录一、接口和抽象类的 “相同点”二、接口和抽象类的 “核心区别”关键区别详解(避免踩坑)三、具体使

MySQL中C接口的实现

《MySQL中C接口的实现》本节内容介绍使用C/C++访问数据库,包括对数据库的增删查改操作,主要是学习一些接口的调用,具有一定的参考价值,感兴趣的可以了解一下... 目录准备mysql库使用mysql库编译文件官方API文档对象的创建和关闭链接数据库下达sql指令select语句前言:本节内容介绍使用C/

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

基于Redisson实现分布式系统下的接口限流

《基于Redisson实现分布式系统下的接口限流》在高并发场景下,接口限流是保障系统稳定性的重要手段,本文将介绍利用Redisson结合Redis实现分布式环境下的接口限流,具有一定的参考价值,感兴趣... 目录分布式限流的核心挑战基于 Redisson 的分布式限流设计思路实现步骤引入依赖定义限流注解实现

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1