SpringBoot整合kaptcha實現(xiàn)圖片驗證碼功能
栗子
登錄
是所有系統(tǒng)都繞不開的一道坎,很多系統(tǒng)會在用戶名和密碼下發(fā)放置一個圖形驗證碼,例如:
這些圖形驗證碼看起來不僅很丑,而且模糊,但卻是保護系統(tǒng)的第一道屏障,它的作用是:設計的初衷其實就是為了防自動化,防止一些人利用自動工具惡意攻擊網(wǎng)站,比如批量注冊,撐爆你的數(shù)據(jù)庫。
實現(xiàn)這個功能并不復雜,但是為了不讓大家重復造輪子,這里我給大家推薦一個現(xiàn)成的輪子:kaptcha
,使用起來非常簡單,廢話不多說直接上代碼。
配置文件
SpringBoot項目中pom.xml文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.1</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>SpringBoot-VerifyCode</artifactId> <version>0.0.1-SNAPSHOT</version> <name>SpringBoot-VerifyCode</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!-- 驗證碼生成包 --> <dependency> <groupId>com.github.penggle</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
項目代碼
項目結構
SpringBootVerifyCodeApplication.java
package com.example.springbootverifycode; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class SpringBootVerifyCodeApplication { public static void main(String[] args) { SpringApplication.run(SpringBootVerifyCodeApplication.class, args); } }
VerifyCodeConfig.java
package com.example.springbootverifycode.config; import com.google.code.kaptcha.Producer; import com.google.code.kaptcha.impl.DefaultKaptcha; import com.google.code.kaptcha.util.Config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import java.util.Properties; @Configuration public class VerifyCodeConfig { @Bean Producer producer() { Properties properties = new Properties(); //設置圖片邊框 properties.setProperty("kaptcha.border", "yes"); //設置圖片邊框為藍色 properties.setProperty("kaptcha.border.color", "blue"); //背景顏色漸變開始 properties.put("kaptcha.background.clear.from", "127,255,212"); //背景顏色漸變結束 properties.put("kaptcha.background.clear.to", "240,255,255"); // 字體顏色 properties.put("kaptcha.textproducer.font.color", "black"); // 文字間隔 properties.put("kaptcha.textproducer.char.space", "10"); //如果需要去掉干擾線 properties.put("kaptcha.noise.impl", "com.google.code.kaptcha.impl.NoNoise"); // 字體 properties.put("kaptcha.textproducer.font.names", "Arial,Courier,cmr10,宋體,楷體,微軟雅黑"); // 圖片寬度 properties.setProperty("kaptcha.image.width", "200"); // 圖片高度 properties.setProperty("kaptcha.image.height", "50"); // 從哪些字符中產(chǎn)生 properties.setProperty("kaptcha.textproducer.char.string", "0123456789abcdefghijklmnopqrsduvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"); // 字符個數(shù) properties.setProperty("kaptcha.textproducer.char.length", "6"); DefaultKaptcha defaultKaptcha = new DefaultKaptcha(); defaultKaptcha.setConfig(new Config(properties)); return defaultKaptcha; } }
KaptchaController.java
package com.example.springbootverifycode.controller; import com.google.code.kaptcha.Producer; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; import javax.imageio.ImageIO; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.awt.image.BufferedImage; import java.io.IOException; @RestController public class KaptchaController { @Autowired private Producer producer; @GetMapping("/getVerifyCode") public void getVerifyCode(HttpServletResponse response, HttpSession session) throws IOException { response.setContentType("image/jpeg"); String text = producer.createText(); session.setAttribute("vf", text); BufferedImage image = producer.createImage(text); try (ServletOutputStream sos = response.getOutputStream()) { ImageIO.write(image, "jpg", sos); } } }
測試
生成運算符驗證碼
1、設置字符個數(shù)為7
// 文字個數(shù) properties.put("kaptcha.textproducer.char.space", "7");
2、獲取圖片
@GetMapping("/getCal") public void getCal(HttpServletResponse response, HttpSession session) throws IOException { response.setContentType("image/jpeg"); //生成文字驗證碼 String text = producer.createText(); System.out.println("當前生成的字符串為:" + text); //個位數(shù)字相加 String s1 = text.substring(0, 2); String s2 = text.substring(2, 4); int count = Integer.valueOf(s1).intValue() + Integer.valueOf(s2).intValue(); System.out.println("計算結果為:" + count); //生成圖片驗證碼 BufferedImage image = producer.createImage(s1 + "+" + s2 + "=?"); try (ServletOutputStream sos = response.getOutputStream()) { ImageIO.write(image, "jpg", sos); } }
3、演示一下
后臺打印:
訪問鏈接:
到此這篇關于SpringBoot整合kaptcha實現(xiàn)圖片驗證碼功能的文章就介紹到這了,更多相關SpringBoot整合kaptcha內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- SpringBoot+kaptcha實現(xiàn)圖片驗證碼功能詳解
- Springboot?+redis+谷歌開源Kaptcha實現(xiàn)圖片驗證碼功能
- SpringBoot集成Kaptcha驗證碼的詳細過程
- SpringBoot使用Kaptcha實現(xiàn)驗證碼的生成與驗證功能
- SpringBoot+kaptcha實現(xiàn)驗證碼花式玩法詳解
- Google Kaptcha 框架實現(xiàn)登錄驗證碼功能(SSM 和 SpringBoot)
- springboot整合kaptcha驗證碼的示例代碼
- SpringBoot 集成Kaptcha實現(xiàn)驗證碼功能實例詳解
- SpringBoot整合Kaptcha實現(xiàn)圖片驗證碼加減乘除功能
相關文章
SpringMVC集成Web與MVC執(zhí)行流程和數(shù)據(jù)響應及交互相關介紹全面總結
Spring MVC 是 Spring 提供的一個基于 MVC 設計模式的輕量級 Web 開發(fā)框架,本質上相當于 Servlet,Spring MVC 角色劃分清晰,分工明細,這篇文章主要介紹了SpringMVC集成Web與MVC執(zhí)行流程和數(shù)據(jù)響應及交互2022-10-10