国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

SpringBoot實(shí)現Thymeleaf驗證碼生成

發(fā)布時(shí)間:2021-07-06 11:13 來(lái)源:腳本之家 閱讀:0 作者:將就嗎 欄目: 開(kāi)發(fā)技術(shù) 歡迎投稿:712375056

使用后臺返回驗證碼圖片,驗證碼存到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í)歡迎投稿傳遞力量。

人与物VIDEOS另类XXXXX| 亚洲一卡一卡二新区无人区| 色综合久久一区二区三区| 中文字幕无码专区一VA亚洲V专区在线| 国产美女爆乳呻吟视频| 亚洲AV成为人电影一区二区三区|