首页 > 其他分享 >使用Spring Boot实现图形验证码:从零开始的详细教程

使用Spring Boot实现图形验证码:从零开始的详细教程

时间:2024-07-18 11:08:22浏览次数:21  
标签:java int Spring Boot 验证码 从零开始 import response

使用Spring Boot实现图形验证码:从零开始的详细教程

在现代Web应用中,图形验证码是一种常见的防止机器人和恶意攻击的手段。今天,我们将深入探讨如何在Spring Boot项目中实现图形验证码。通过这个教程,你将学会如何生成和验证图形验证码,并将其集成到你的Spring Boot应用中。

一、项目初始化

首先,我们需要创建一个Spring Boot项目。如果你还没有Spring Boot项目,可以使用Spring Initializr快速生成一个。

  1. 打开 Spring Initializr
  2. 选择以下配置:
    • Project: Maven Project
    • Language: Java
    • Spring Boot: 2.5.4 (或最新版本)
    • Dependencies: Spring Web
  3. 点击“Generate”按钮,下载生成的项目并解压。

二、添加依赖

在你的pom.xml文件中添加以下依赖:

<dependencies>
    <!-- Spring Web -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- FastJSON for JSON processing -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.76</version>
    </dependency>
</dependencies>

三、生成图形验证码

接下来,我们需要编写生成图形验证码的代码。我们将创建一个工具类来生成验证码图片。

1. 创建验证码工具类

src/main/java/com/example/demo/utils目录下创建一个名为CaptchaUtil.java的文件,并添加以下代码:

package com.example.demo.utils;

import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.Random;

public class CaptchaUtil {

    private static final int WIDTH = 160;
    private static final int HEIGHT = 40;
    private static final int CODE_COUNT = 4;
    private static final int FONT_HEIGHT = 30;
    private static final int CODE_Y = 30;
    private static final char[] CODE_SEQUENCE = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890".toCharArray();

    public static BufferedImage generateCaptchaImage(StringBuilder code) {
        BufferedImage buffImg = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
        Graphics2D g = buffImg.createGraphics();
        Random random = new Random();

        g.setColor(Color.WHITE);
        g.fillRect(0, 0, WIDTH, HEIGHT);

        Font font = new Font("Fixedsys", Font.BOLD, FONT_HEIGHT);
        g.setFont(font);

        g.setColor(Color.BLACK);
        g.drawRect(0, 0, WIDTH - 1, HEIGHT - 1);

        g.setColor(Color.BLACK);
        for (int i = 0; i < 30; i++) {
            int x = random.nextInt(WIDTH);
            int y = random.nextInt(HEIGHT);
            int xl = random.nextInt(12);
            int yl = random.nextInt(12);
            g.drawLine(x, y, x + xl, y + yl);
        }

        int red, green, blue;
        for (int i = 0; i < CODE_COUNT; i++) {
            String codeStr = String.valueOf(CODE_SEQUENCE[random.nextInt(CODE_SEQUENCE.length)]);
            red = random.nextInt(255);
            green = random.nextInt(255);
            blue = random.nextInt(255);

            g.setColor(new Color(red, green, blue));
            g.drawString(codeStr, (i + 1) * 30, CODE_Y);

            code.append(codeStr);
        }

        return buffImg;
    }
}

2. 创建验证码控制器

src/main/java/com/example/demo/controller目录下创建一个名为CaptchaController.java的文件,并添加以下代码:

package com.example.demo.controller;

import com.example.demo.utils.CaptchaUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletResponse;
import java.awt.image.BufferedImage;
import java.io.IOException;

@RestController
public class CaptchaController {

    @GetMapping("/captcha")
    public void getCaptcha(HttpServletResponse response) throws IOException {
        StringBuilder code = new StringBuilder();
        BufferedImage captchaImage = CaptchaUtil.generateCaptchaImage(code);

        response.setContentType("image/jpeg");
        response.setHeader("Pragma", "No-cache");
        response.setHeader("Cache-Control", "no-cache");
        response.setDateHeader("Expire", 0);

        ImageIO.write(captchaImage, "jpeg", response.getOutputStream());
    }
}

四、测试图形验证码

启动你的Spring Boot应用,打开浏览器并访问http://localhost:8080/captcha。你应该会看到一个随机生成的图形验证码。

五、验证图形验证码

为了验证用户输入的验证码,我们需要将生成的验证码存储在服务器端,并在用户提交时进行比对。这里我们使用Spring Session来存储验证码。

1. 添加Spring Session依赖

pom.xml文件中添加以下依赖:

<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-core</artifactId>
</dependency>

2. 配置Spring Session

src/main/resources/application.properties文件中添加以下配置:

spring.session.store-type=jdbc

3. 修改验证码控制器

我们需要将生成的验证码存储在Session中,并在用户提交时进行比对。

package com.example.demo.controller;

import com.example.demo.utils.CaptchaUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.image.BufferedImage;
import java.io.IOException;

@RestController
public class CaptchaController {

    @GetMapping("/captcha")
    public void getCaptcha(HttpServletRequest request, HttpServletResponse response) throws IOException {
        StringBuilder code = new StringBuilder();
        BufferedImage captchaImage = CaptchaUtil.generateCaptchaImage(code);

        request.getSession().setAttribute("captcha", code.toString());

        response.setContentType("image/jpeg");
        response.setHeader("Pragma", "No-cache");
        response.setHeader("Cache-Control", "no-cache");
        response.setDateHeader("Expire", 0);

        ImageIO.write(captchaImage, "jpeg", response.getOutputStream());
    }

    @PostMapping("/verifyCaptcha")
    public String verifyCaptcha(HttpServletRequest request, @RequestParam("captcha") String captcha) {
        String sessionCaptcha = (String) request.getSession().getAttribute("captcha");
        if (sessionCaptcha != null && sessionCaptcha.equalsIgnoreCase(captcha)) {
            return "Captcha verified successfully!";
        } else {
            return "Captcha verification failed!";
        }
    }
}

六、总结

通过这个教程,我们从零开始在Spring Boot项目中实现了图形验证码的生成和验证。我们创建了一个工具类来生成验证码图片,并通过控制器将其展示给用户。同时,我们使用Spring Session来存储验证码,并在用户提交时进行比对。

希望这个教程对你有所帮助!如果你有任何问题或建议,欢迎在评论区留言。Happy coding!

百万大学生都在用的AI写论文工具,篇篇无重复

标签:java,int,Spring,Boot,验证码,从零开始,import,response
From: https://www.cnblogs.com/zhizu/p/18309094

相关文章

  • SpringBoot与Thymeleaf模板技术整合
    以下是一个简单的SpringBoot整合Thymeleaf的入门案例:1.创建一个SpringBoot项目,并添加Thymeleaf依赖。org.springframework.bootspring-boot-starter-thymeleaforg.springframework.bootspring-boot-starter-web2.在src/main/resources/templates目录下创建一个HTML模......
  • 【终极指南】从零开始征服机器学习:初学者的黄金路线图
       踏入机器学习的世界,对许多初学者而言,无疑是一场既兴奋又略带忐忑的冒险。尤其对于那些非数学或计算机专业背景的同学,或是已经在职场打拼的朋友们,寻找一条适合自己的入门路径,显得尤为重要。鉴于此,本文将结合个人经验与导师建议,精心整理一份机器学习学习指南,希望能为渴......
  • Flash简介及其中的Bootloader如何实现对APP程序的下载更新或重装
    目录1.eMMC、NandFlash都属于Flash,Flash的具体类别如下2.Bootloader在APP程序下载更新或重装中存在的意义3.Bootloader下载更新或重装APP程序的思路框架4.Bootloader下载更新或重装APP程序代码实现1.eMMC、NandFlash都属于Flash,Flash的具体类别如下       ......
  • Vue.js 集成高德地图:从零开始的实战指南
    Vue.js集成高德地图:从零开始的实战指南在现代Web开发中,地图服务已经成为许多应用的核心功能之一。高德地图作为国内领先的地图服务提供商,提供了强大的API接口,方便开发者在应用中集成地图功能。今天,我们将深入探讨如何在Vue.js项目中集成高德地图,并通过实际代码示例来展示......
  • 基于java+springboot+vue的影视影院订票选座管理系统(源码+LW+部署讲解)
    前言......
  • 基于java+springboot+vue的学生毕业离校系统(源码+LW+部署讲解)
    前言......
  • 从头理清uboot(2)-启动流程分析
    从头理清uboot(2)-启动流程分析目录从头理清uboot(2)-启动流程分析1.总体流程图2.逐步分析2.1上电后执行的第一条指令2.2初始化中断向量表2.3初始化工作模式&初始化中断向量表。2.4cpu_init_cp15&cpu_init_crit2.4.1cpu_init_cp152.4.1cpu_init_crit2.5进入_main函数2.5......
  • SpringMVC:@ResponseBody注解与HttpServletResponse对象
    在SpringMVC框架中,@ResponseBody注解和HttpServletResponse对象都扮演着将处理结果发送回客户端的重要角色,但它们的使用方式和目的有所不同。@ResponseBody@ResponseBody注解用于将方法的返回值绑定到web响应体(responsebody)上。当你使用@ResponseBody注解一个方法的返回值时,Sp......
  • 【第3章】Spring Cloud之Nacos服务端权限认证
    文章目录前言一、默认控制台登录页二、鉴权1.相关参数2.服务端开启鉴权2.1开启鉴权2.2自定义密钥3.开启服务身份识别功能4.开启Token缓存功能三、效果四、用户列表总结前言上一章我们访问了控制台,这里为了安全我们开启Nacos的权限认证。一、默认控制台登录......
  • 【第4章】Spring Cloud之Nacos单机模式支持mysql
    文章目录前言一、初始化1.初始化数据库2.修改配置文件二、效果1.重新启动2.新增用户总结前言在0.7版本之前,在单机模式时nacos使用嵌入式数据库实现数据的存储,不方便观察数据存储的基本情况。0.7版本增加了支持mysql数据源能力,具体的操作步骤:安装数据库,版本要......