- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) >
- SpringBoot實(shí)現Thymeleaf驗證碼生成
使用后臺返回驗證碼圖片,驗證碼存到session中后端實(shí)現校驗,前端只展示驗證碼圖片。
本篇用SpringBoot Thymeleaf實(shí)現驗證碼生成。
創(chuàng )建springboot項目 引入依賴(lài)
完整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.2.6.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>web</artifactId> <version>0.0.1-SNAPSHOT</version> <name>web</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> <exclusions> <exclusion> <groupId>org.junit.vintage</groupId> <artifactId>junit-vintage-engine</artifactId> </exclusion> </exclusions> </dependency> <!-- ThymeLeaf 依賴(lài) --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
application.yml配置 Thymeleaf
#Thymeleaf配置 spring: mvc: static-path-pattern: /** thymeleaf: mode: HTML encoding: UTF-8 #關(guān)閉緩存 cache: false
創(chuàng )建CaptchaController.java 類(lèi)
package com.example.web.controller; import com.example.web.util.VerifyCode; import org.springframework.web.bind.annotation.RequestMapping; 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; import java.io.OutputStream; @RestController public class CaptchaController { /* 獲取驗證碼圖片*/ @RequestMapping("/getVerifyCode") public void getVerificationCode(HttpServletResponse response, HttpServletRequest request) { try { int width = 200; int height = 69; BufferedImage verifyImg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);//生成對應寬高的初始圖片 String randomText = VerifyCode.drawRandomText(width, height, verifyImg);//單獨的一個(gè)類(lèi)方法,出于代碼復用考慮,進(jìn)行了封裝。功能是生成驗證碼字符并加上噪點(diǎn),干擾線(xiàn),返回值為驗證碼字符 request.getSession().setAttribute("verifyCode", randomText); response.setContentType("image/png");//必須設置響應內容類(lèi)型為圖片,否則前臺不識別 OutputStream os = response.getOutputStream(); //獲取文件輸出流 ImageIO.write(verifyImg, "png", os);//輸出圖片流 os.flush(); os.close();//關(guān)閉流 } catch (IOException e) { e.printStackTrace(); } } }
創(chuàng )建VerifyCode.java 工具類(lèi)
package com.example.web.util; import java.awt.*; import java.awt.image.BufferedImage; import java.util.Random; public class VerifyCode { public static String drawRandomText(int width, int height, BufferedImage verifyImg) { Graphics2D graphics = (Graphics2D) verifyImg.getGraphics(); graphics.setColor(Color.WHITE);//設置畫(huà)筆顏色-驗證碼背景色 graphics.fillRect(0, 0, width, height);//填充背景 graphics.setFont(new Font("微軟雅黑", Font.BOLD, 40)); //數字和字母的組合 String baseNumLetter = "123456789abcdefghijklmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"; StringBuilder builder = new StringBuilder(); int x = 10; //旋轉原點(diǎn)的 x 坐標 String ch; Random random = new Random(); for (int i = 0; i < 4; i++) { graphics.setColor(getRandomColor()); //設置字體旋轉角度 int degree = random.nextInt() % 30; //角度小于30度 int dot = random.nextInt(baseNumLetter.length()); ch = baseNumLetter.charAt(dot) + ""; builder.append(ch); //正向旋轉 graphics.rotate(degree * Math.PI / 180, x, 45); graphics.drawString(ch, x, 45); //反向旋轉 graphics.rotate(-degree * Math.PI / 180, x, 45); x += 48; } //畫(huà)干擾線(xiàn) for (int i = 0; i < 6; i++) { // 設置隨機顏色 graphics.setColor(getRandomColor()); // 隨機畫(huà)線(xiàn) graphics.drawLine(random.nextInt(width), random.nextInt(height), random.nextInt(width), random.nextInt(height)); } //添加噪點(diǎn) for (int i = 0; i < 30; i++) { int x1 = random.nextInt(width); int y1 = random.nextInt(height); graphics.setColor(getRandomColor()); graphics.fillRect(x1, y1, 2, 2); } return builder.toString(); } /** * 隨機取色 */ private static Color getRandomColor() { Random ran = new Random(); return new Color(ran.nextInt(256), ran.nextInt(256), ran.nextInt(256)); } }
創(chuàng )建UserController.java 類(lèi)
package com.example.web.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; @Controller public class UserController { @RequestMapping("/login") public String login() { return "login"; } }
resources/templates目錄下創(chuàng )建login.html
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Show User</title> </head> <body> <a href="javascript:void(0);" rel="external nofollow" title="點(diǎn)擊更換驗證碼"> <img th:src="@{getVerifyCode}" onclick="changeCode()" class="verifyCode"/> </a> </body> <!-- 引入JQuery --> <script src="../static/js/jquery.min.js" th:src="@{/js/jquery.min.js}"></script> <script> function changeCode() { const src = "/getVerifyCode?" + new Date().getTime(); //加時(shí)間戳,防止瀏覽器利用緩存 $('.verifyCode').attr("src", src); } </script> </html>
啟動(dòng)項目訪(fǎng)問(wèn)http://localhost:8080/login
點(diǎn)擊圖片可以更換驗證碼,至于后面的后臺驗證就不講了。
參考文章
到此這篇關(guān)于SpringBoot實(shí)現Thymeleaf驗證碼生成的文章就介紹到這了,更多相關(guān)SpringBoot Thymeleaf驗證碼生成內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站