【Java 进阶篇】Java Web开发:实现验证码功能

news2024/11/29 2:38:28

在这里插入图片描述

在Web应用程序中,验证码(CAPTCHA)是一种常见的安全工具,用于验证用户是否为人类而不是机器。验证码通常以图像形式呈现,要求用户在登录或注册时输入正确的字符。在这篇文章中,我们将详细介绍如何在Java Web应用程序中实现验证码功能。

什么是验证码?

验证码是“全自动区分计算机和人类的公证测试”(Completely Automated Public Turing test to tell Computers and Humans Apart)的缩写。它是一种用于识别用户是否为真实人类的技术。验证码通常包括一个随机生成的字符串,用户需要在输入框中输入正确的字符串以证明他们不是机器人。

验证码的主要目的是防止自动化机器人攻击,例如恶意注册帐户、暴力破解密码或发垃圾邮件。通过要求用户执行某种人类可识别的操作,如识别字符或选择特定图像,可以降低自动化机器人的效率。

验证码的种类

在Web开发中,有多种类型的验证码,包括:

  1. 字符验证码:用户需要识别并输入一个包含随机字符的图像。
  2. 图像验证码:用户需要在一组图像中选择特定的图像,以证明他们是人类。
  3. 数学验证码:用户需要解决一个简单的数学问题,如加法或减法,以证明他们是人类。
  4. 音频验证码:用户需要听取和输入一个音频中的数字或单词。
  5. 滑块验证码:用户需要拖动一个滑块来证明他们是人类。

在本文中,我们将重点介绍字符验证码的实现,这是最常见的验证码类型之一。

实现字符验证码

要实现字符验证码,我们将使用Java的Servlet技术和一些开源库。以下是步骤:

步骤1:创建一个新的Java Web项目

首先,您需要创建一个新的Java Web项目。您可以使用Eclipse、IntelliJ IDEA或任何其他您喜欢的IDE。在项目中,创建一个新的Servlet,我们将在其中实现验证码生成和呈现。

步骤2:导入必要的库

为了生成验证码图像,我们将使用Java的BufferedImage类。此外,我们还需要用于生成随机字符的Java库。在web.xml文件中,将Servlet的URL映射设置为您希望验证码可访问的URL路径。

<servlet>
    <servlet-name>CaptchaServlet</servlet-name>
    <servlet-class>com.example.CaptchaServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>CaptchaServlet</servlet-name>
    <url-pattern>/captcha</url-pattern>
</servlet-mapping>

步骤3:实现CaptchaServlet

现在,我们将实现CaptchaServlet,这是生成和呈现验证码的核心部分。以下是一个示例实现:

@WebServlet("/captcha")
public class CaptchaServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        int width = 200;
        int height = 50;

        // 创建一个图像缓冲区
        BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

        // 获取图形上下文
        Graphics2D g2d = bufferedImage.createGraphics();

        // 设置背景颜色
        g2d.setColor(Color.white);
        g2d.fillRect(0, 0, width, height);

        // 生成随机字符
        String captchaText = generateRandomString(5); // 生成包含5个字符的随机字符串

        // 将验证码文本存储在Session中,以便稍后验证
        HttpSession session = request.getSession();
        session.setAttribute("captcha", captchaText);

        // 设置字体和字体大小
        g2d.setFont(new Font("SansSerif", Font.BOLD, 24));

        // 设置文本颜色
        g2d.setColor(Color.black);

        // 在图像上绘制验证码文本
        g2d.drawString(captchaText, 50, 30);

        // 添加一些噪音,使验证码更难以识别
        addNoise(g2d, width, height);

        // 设置响应内容类型
        response.setContentType("image/png");

        // 获取响应的输出流
        OutputStream os = response.getOutputStream();

        // 将图像写入响应
        ImageIO.write(bufferedImage, "png", os);

        // 关闭输出流
        os.close();
    }

    // 生成随机字符串
    private String generateRandomString(int length) {
        String characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
        StringBuilder randomString = new StringBuilder();
        Random random = new Random();

        for (int i = 0; i < length; i++) {
            int index = random.nextInt(characters.length());
            randomString.append(characters.charAt(index));
        }

        return randomString.toString();
    }

    // 添加噪音
    private void addNoise(Graphics2D g2d, int width, int height) {
        Random random = new Random();
        for (int i = 0; i < 100; i++) {
            int x = random.nextInt(width);
            int y = random.nextInt(height);
            int size = random.nextInt(5);
            g2d.setColor(new Color(random.nextFloat(), random.nextFloat(), random.nextFloat()));
            g2d.fillRect(x, y, size, size);
        }
    }
}

在这个示例中,我们首先创建一个BufferedImage对象,然后使用Graphics2D对象绘制验证码图像。验证码文本是通过generateRandomString方法生成的,并存储在Session中以供稍后验证。最后,我们将图像写入响应的输出流。

步骤4:在JSP页面中显示验证码

要在JSP页面中显示验证码,您可以使用以下代码:

<img src="captcha" alt="Captcha Image" />

这将在页面上显示生成的验证码图像。用户可以查看并输入验证码。

步骤5:验证用户输入

为了验证用户输入的验证码是否正确,您需要在提交表单时进行检查。通常,用户的输入将与存储在Session中的验证码进行比较。

以下是一个示例JSP表单,用户可以在其中输入验证码:

<form action="login" method="post">
    <label for="username">Username:</label>
    <input type="text" name="username" id="username" required>
    <br>
    <label for="password">Password:</label>
    <input type="password" name="password" id="password" required>
    <br>
    <label for="captcha">Captcha:</label>
    <input type="text" name="captcha" id="captcha" required>
    <img src="captcha" alt="Captcha Image" />
    <br>
    <input type="submit" value="Login">
</form>

步骤6:验证用户输入

在处理登录请求时,您可以验证用户输入的验证码是否与存储在Session中的验证码匹配。以下是一个示例Servlet,用于处理登录请求和验证验证码:

@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        String enteredCaptcha = request.getParameter("captcha");

        HttpSession session = request.getSession();
        String storedCaptcha = (String) session.getAttribute("captcha");

        if (enteredCaptcha != null && enteredCaptcha.equals(storedCaptcha)) {
            // 验证码正确,继续处理登录
            if ("admin".equals(username) && "password".equals(password)) {
                // 登录成功
                response.getWriter().write("Login successful");
            } else {
                // 登录失败
                response.getWriter().write("Login failed");
            }
        } else {
            // 验证码错误
            response.getWriter().write("Invalid captcha");
        }
    }
}

在此示例中,我们首先从用户请求中获取用户名、密码和输入的验证码。然后,我们检查输入的验证码是否与存储在Session中的验证码匹配。如果验证码正确,我们继续验证用户名和密码。如果一切都正确,用户将获得成功的消息。否则,他们将收到适当的错误消息。

总结

验证码是Web应用程序中常用的安全工具,用于防止自动化机器人攻击。通过实现字符验证码,您可以有效地保护您的应用程序免受恶意活动的影响。

在本文中,我们介绍了如何使用Java Servlet技术创建和显示验证码图像,以及如何在用户登录时验证用户的输入。这只是验证码实现的一个示例,您可以根据需要进行自定义和扩展。希望这篇文章能帮助您实现验证码功能,提高您Web应用程序的安全性。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1160006.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NEFU离散数学实验特别篇1-树和图

树相关概念 离散数学中&#xff0c;树是一种重要的数据结构&#xff0c;它是一种无向连通图&#xff0c;并且不存在环。下面是树的相关概念和公式&#xff1a; 1. 顶点数为n的树&#xff0c;边数为n-1。 2. 度数为k的树中有k个分支。 3. 一棵树中最多只有两个度数大于1的顶点&a…

京东API获得JD商品详情 item_get-获得JD商品详情

item_get-获得JD商品详情 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;获取key和secret接入secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,item_get,item_sear…

面经(面试经验)第一步,从自我介绍开始说起

看到一位同学讲自己的面试步骤和过程&#xff0c;我心有所感&#xff0c;故此想整理下面试的准备工作。以便大家能顺利应对面试&#xff0c;通过面试... 求职应聘找工作&#xff0c;面试是必然的关卡&#xff0c;如今竞争激烈呀&#xff0c;想要得到自己喜欢的工作&#xff0c…

U盘装系统Win10步骤和详细教程

如果我们遇到系统问题&#xff0c;导致无法正常使用系统了&#xff0c;这时候就可以考虑给电脑重新安装系统。有用户想用U盘来进行系统的重装&#xff0c;但不清楚具体重装步骤&#xff0c;下面小编给大家详细介绍关于U盘重装系统Win10的详细步骤方法&#xff0c;帮助大家简单轻…

请求转发和重定向的区别

目录 一、请求转发 二、重定向 一、请求转发 request.getRequestDispatcher(页面).forwad(request,response) 请求转发&#xff1a; 客户端&#xff08;浏览器&#xff09;向服务器的资源 A 发起一次请求 ①。服务器的资源 A 接收到该请求后&#xff0c;将该请求转发到内部的…

FedAT:异步更新联邦学习方法

文章链接&#xff1a;FedAT: A Communication-Efficient Federated Learning Method with Asynchronous Tiers under Non-IID Data 发表会议: SC’21 (International Conference for High Performance Computing, Networking, Storage, and Analysis) 高性能计算&#xff0c;体…

高能有料 | 第二届OpenHarmony技术大会议程速递

第二届开放原子开源基金会OpenHarmony技术大会如约而至 让我们一起 开封无限惊喜的技术成果 开放无限前沿的议题干货 开启无限可能的未来之门 点击此处报名参会&#xff01;

接口自动化测试设计!

一、接口测试基础 1.什么是接口测试&#xff1f; 接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。接口测试的重点是要检查数据的交换&#xff0c;传递和控制管理过程&#xff0c;以及系统间的相互逻辑依赖…

01【保姆级】-GO语言特点 下载安装 hello

01-GO语言基本概念和安装使用 一、概念1.1 Go语言的诞生1.2 GO语言的特点&#xff1a; 二、安装go2.1 安装2.2 安装环境变量 三、下载&安装goland3.1 官网下载3.2 下载后&#xff0c;进行安装&#xff1a; 四、Go语言的特性&#xff08;重点&#xff09;4.1 第一个hello wo…

Spire.doc读取模板文档,并在书签处插入内容

在书签位置插入文字 //加载模板文档 Document document new Document(Server.MapPath("~/File/评价结果.doc")); //创建书签导航器 BookmarksNavigator bn new BookmarksNavigator(document); //添加一个section到文档 Section newSec document.AddSection(); …

Redis Sentinel 哨兵模式

Sentinel 哨兵模式 Redis Sentinel 官网 Redis 的 Sentinel 文档 -- Redis中国用户组&#xff08;CRUG&#xff09; Sentinel Redis 命令参考&#xff08;红色&#xff09; Sentinel 通过监控的方式获取主机的工作状态是否正常&#xff0c;当主机发生故障时&#xff0c; Senti…

生产制造业如何进行进销存管理?建议收藏!

进销存是什么&#xff1f;生产制造业如何进行进销存管理&#xff1f;制造进销存都能为企业提供什么&#xff1f;进销存管理系统的优势&#xff1f;本文将带大家深入浅出的聊聊制造进销存&#xff0c;全面剖析制造进销存的前世今生&#xff0c;并且为大家提供2023年十大制造进销…

「linux基础」上传代码到github/gitee

一、在gitee创建一个仓库 1.创建仓库 2.获取仓库地址 二、克隆仓库文件到linux中 1.查看Linux中是否安装git&#xff1a;git --version 如果没有&#xff0c;在root下使用指令 yum install -y git 安装。 2.使用 git clone 仓库地址&#xff0c;克隆仓库文件到linux中 三、第…

第一章 02Java入门-常环境变量的意义

前言 上次我们学习了常见的CMD命令,这次我们做一个用它做一个练习打开QQ(CMD方式打开),最后引出环境变量的意义。 一、CMD打开qq 可以看到,如果直接在CMD里面打开QQ,是不可以的,因为QQ的路径不在默认路径C盘,而在D盘下面的develop文件夹下面的qq下面的qq.exe下(自己…

软考高级之系统架构师之计算专题

操作系统 需要一定操作系统基础知识才能计算的题目。 吞吐率 某指令流水线由5段组成&#xff0c;各段所需要的时间如下图所示。连续输入100条指令时的吞吐率为&#xff08;&#xff09;。 解析&#xff1a; 指令流水线的吞吐率定义为&#xff1a; 吞吐率 T P 指令数 执行时…

Gcov 查看代码覆盖率

GCOV 工具简介 gcov是一个测试代码覆盖率的工具。 它是 gcc 自带的查看代码覆盖率的工具&#xff0c;无需额外安装&#xff0c;在嵌入式的 arm-eabi-none-gcc 中同样可以使用&#xff08;需要重写部分系统函数&#xff09;。 使用效果如下图所示&#xff1a; 程序运行完成后…

云尘-Potato(Suncsr)1

vulhub的题目 继续渗透吧 我们依旧打开nmap 开扫 首先扫描目标网段nmap -sP 127.25.0.1/24 nmap -sS -sV -p- -v 172.25.0.13然后扫描端口 获取到两个 80和 7120 80机会很多 22就一次 爆破弱口令 报完没有就去80测试 hydra -l potato -P 字典 -vV ssh://172.25.0.13:7120 …

MySQL数据库入门到精通——运维篇(1)

MySQL数据库入门到精通——运维篇&#xff08;1&#xff09; 1. 日志1.1 错误日志1.2 二进制日志1.3 查询日志1.4 慢查询日志 2. 主从复制2.1 主从复制的概述2.2 主从复制的原理2.3 主从复制的搭建2.3.1 服务器准备2.3.2 主库配置2.3.3 从库配置2.3.4 测试 1. 日志 在任何一种…

轻量封装WebGPU渲染系统示例<11>- WebGP实现的简单PBR效果(源码)

当前示例源码github地址: https://github.com/vilyLei/voxwebgpu/blob/main/src/voxgpu/sample/SimplePBRTest.ts 此示例渲染系统实现的特性: 1. 用户态与系统态隔离。 2. 高频调用与低频调用隔离。 3. 面向用户的易用性封装。 4. 渲染数据和渲染机制分离。 5. 用户操作…

【Linux】第九站:make和makefile

文章目录 一、 Linux项目自动化构建工具make/Makefile1.make/makefile工作现象2.依赖关系与依赖方法3.如何清理4.为什么这里我们需要带上clean5.连续的make6.特殊符号 二、Linux下实现一个简单的进度条1.回车换行2.缓冲区3.倒计时的实现 一、 Linux项目自动化构建工具make/Make…