欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+vue實(shí)現(xiàn)登錄圖片驗(yàn)證碼功能

 更新時間:2023年07月02日 14:28:24   作者:Mr順  
這篇文章主要給大家介紹一下如何SpringBoot+vue實(shí)現(xiàn)登錄圖片驗(yàn)證碼功能,文中有詳細(xì)的代碼示例,具有一定的參考價值,需要的朋友可以參考下

SpringBoot+vue實(shí)現(xiàn)登錄圖片驗(yàn)證碼

要在Spring Boot和Vue中實(shí)現(xiàn)登錄時的圖片驗(yàn)證碼功能,可以按照以下步驟進(jìn)行操作:
后端(Spring Boot)實(shí)現(xiàn):
添加相關(guān)依賴:在
pom.xml文件中添加以下依賴:

<dependency>
    <groupId>nl.captcha</groupId>
    <artifactId>simplecaptcha</artifactId>
    <version>1.2.2</version>
</dependency>

創(chuàng)建一個驗(yàn)證碼生成器:創(chuàng)建一個CaptchaGenerator類,用于生成驗(yàn)證碼圖片。

import nl.captcha.Captcha;
import nl.captcha.backgrounds.FlatColorBackgroundProducer;
import nl.captcha.gimpy.DropShadowGimpyRenderer;
import nl.captcha.text.producer.DefaultTextProducer;
import nl.captcha.text.renderer.DefaultWordRenderer;
import org.springframework.stereotype.Component;
import javax.imageio.ImageIO;
import java.awt.*;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
@Component
public class CaptchaGenerator {
    public byte[] generateCaptchaImage(String captchaText) {
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        // 創(chuàng)建驗(yàn)證碼圖片對象
        Captcha captcha = new Captcha.Builder(200, 50)
                .addText(new DefaultTextProducer(), new DefaultWordRenderer())
                .gimp(new DropShadowGimpyRenderer())
                .addBackground(new FlatColorBackgroundProducer(Color.WHITE))
                .build();
        try {
            // 將驗(yàn)證碼圖片寫入輸出流
            ImageIO.write(captcha.getImage(), "png", outputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return outputStream.toByteArray();
    }
}

創(chuàng)建一個REST API接口:創(chuàng)建一個
CaptchaController類,用于生成驗(yàn)證碼圖片的API接口。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@RestController
@RequestMapping("/api/captcha")
public class CaptchaController {
    private final CaptchaGenerator captchaGenerator;
    @Autowired
    public CaptchaController(CaptchaGenerator captchaGenerator) {
        this.captchaGenerator = captchaGenerator;
    }
    @GetMapping
    public void generateCaptcha(HttpServletResponse response) throws IOException {
        // 生成驗(yàn)證碼圖片的方法
        byte[] captchaImage = captchaGenerator.generateCaptchaImage("1234");
        // 設(shè)置響應(yīng)的內(nèi)容類型為圖片
        response.setContentType("image/png");
        // 將驗(yàn)證碼圖片寫入響應(yīng)輸出流
        response.getOutputStream().write(captchaImage);
    }
}

啟動應(yīng)用程序:啟動Spring Boot應(yīng)用程序,確保REST API接口可用。
前端(Vue)實(shí)現(xiàn):
創(chuàng)建一個驗(yàn)證碼組件:創(chuàng)建一個Captcha.vue組件,用于顯示驗(yàn)證碼圖片。

<template>
  <div>
    <!-- 顯示驗(yàn)證碼圖片,點(diǎn)擊圖片刷新驗(yàn)證碼 -->
    <img :src="captchaImage" alt="Captcha" @click="refreshCaptcha" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      captchaImage: "" // 驗(yàn)證碼圖片的URL
    };
  },
  mounted() {
    this.refreshCaptcha(); // 組件掛載時刷新驗(yàn)證碼
  },
  methods: {
    refreshCaptcha() {
      this.captchaImage = `/api/captcha?t=${Date.now()}`; // 刷新驗(yàn)證碼圖片的URL,添加時間戳以避免緩存
    }
  }
};
</script>
<style scoped>
img {
  cursor: pointer; // 設(shè)置鼠標(biāo)指針樣式為手型
}
</style>

在登錄頁面使用驗(yàn)證碼組件:在你的登錄頁面的代碼中,使用Captcha組件來顯示驗(yàn)證碼圖片,并在表單中添加一個輸入框用于用戶輸入驗(yàn)證碼。

<template>
  <div>
    <h1>Login Page</h1>
    <form @submit="submitForm">
      <input type="text" v-model="username" placeholder="Username" />
      <input type="password" v-model="password" placeholder="Password" />
      <!-- 顯示驗(yàn)證碼圖片,并添加點(diǎn)擊事件刷新驗(yàn)證碼 -->
      <input type="text" v-model="captcha" placeholder="Captcha" />
      <captcha></captcha>
      <button type="submit">Login</button>
    </form>
  </div>
</template>
<script>
import Captcha from "@/components/Captcha.vue";
export default {
  data() {
    return {
      username: "",
      password: "",
      captcha: ""
    };
  },
  methods: {
    submitForm() {
      // 在此處進(jìn)行登錄驗(yàn)證和驗(yàn)證碼驗(yàn)證的邏輯
      console.log("Username:", this.username);
      console.log("Password:", this.password);
      console.log("Captcha:", this.captcha);
    }
  },
  components: {
    Captcha
  }
};
</script>

這樣,當(dāng)用戶訪問登錄頁面時,會生成并顯示一個驗(yàn)證碼圖片。用戶可以點(diǎn)擊驗(yàn)證碼圖片來刷新驗(yàn)證碼。在提交登錄表單時,你可以在后端進(jìn)行相應(yīng)的驗(yàn)證碼驗(yàn)證邏輯,以確保用戶輸入的驗(yàn)證碼與生成的驗(yàn)證碼一致。
請確保你已正確安裝了相關(guān)依賴,并根據(jù)你的項(xiàng)目結(jié)構(gòu)和需求進(jìn)行相應(yīng)的路徑和配置調(diào)整。以上代碼只是一個示例,你可以根據(jù)實(shí)際情況進(jìn)行修改和擴(kuò)展。

擴(kuò)展

<dependency> 是 Maven 項(xiàng)目中用于管理依賴的標(biāo)簽。在這段代碼中,<dependency> 標(biāo)簽用于指定項(xiàng)目所依賴的庫(Artifact)的相關(guān)信息。
具體來說:
<groupId>:指定庫的 Group ID,即庫所屬的組織或者項(xiàng)目的標(biāo)識符。在這里,
nl.captcha 表示這個庫是由名為 “nl.captcha” 的組織提供。
<artifactId>:指定庫的 Artifact ID,即庫的唯一標(biāo)識符。在這里,
simplecaptcha 表示這個庫的名稱為 “simplecaptcha”。
<version>:指定庫的版本號。在這里,
1.2.2 表示使用的是 “simplecaptcha” 庫的版本 1.2.2。
通過在 Maven 項(xiàng)目的 pom.xml 文件中添加這段 <dependency> 代碼,你就可以告訴 Maven 構(gòu)建系統(tǒng),你的項(xiàng)目需要使用 “simplecaptcha” 庫,并且指定了具體的版本號。當(dāng)你構(gòu)建項(xiàng)目時,Maven 會自動下載并管理這個庫的相關(guān)依賴。
簡而言之,這段代碼的目的是在 Maven 項(xiàng)目中添加 “simplecaptcha” 庫作為項(xiàng)目的依賴,以便在代碼中使用該庫提供的功能。
SimpleCaptcha 是一個開源的 Java 庫,用于生成和驗(yàn)證圖像驗(yàn)證碼。它提供了一個簡單而靈活的方式來創(chuàng)建各種類型的驗(yàn)證碼,包括文本、數(shù)字、字母、數(shù)學(xué)等。
SimpleCaptcha 的主要特點(diǎn)和功能包括:
高度可定制化:SimpleCaptcha 允許你通過配置各種參數(shù)來定制生成的驗(yàn)證碼,例如驗(yàn)證碼的長度、字體樣式、字體顏色、背景樣式、干擾線等。你可以根據(jù)自己的需求創(chuàng)建符合你應(yīng)用程序風(fēng)格的驗(yàn)證碼。

多種驗(yàn)證碼類型:SimpleCaptcha 支持多種驗(yàn)證碼類型,包括文本驗(yàn)證碼、數(shù)字驗(yàn)證碼、字母驗(yàn)證碼、數(shù)學(xué)驗(yàn)證碼等。你可以選擇適合你應(yīng)用場景的驗(yàn)證碼類型。

高度可讀性:生成的驗(yàn)證碼圖像具有良好的可讀性,確保用戶能夠輕松辨認(rèn)驗(yàn)證碼。

防止自動化攻擊:通過添加干擾線、噪點(diǎn)等特征,SimpleCaptcha 增加了驗(yàn)證碼的復(fù)雜度,提高了驗(yàn)證碼的安全性,減少了自動化攻擊的風(fēng)險。

簡單易用:SimpleCaptcha 提供了簡單的 API,使得在你的 Java 應(yīng)用程序中集成和使用驗(yàn)證碼變得非常容易。

可以使用 SimpleCaptcha 來為你的應(yīng)用程序添加驗(yàn)證碼功能,以增強(qiáng)用戶驗(yàn)證和安全性。它適用于各種場景,如用戶注冊、登錄、重置密碼、防止惡意攻擊等。

以上就是SpringBoot+vue實(shí)現(xiàn)登錄圖片驗(yàn)證碼功能的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot+vue圖片驗(yàn)證碼的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java在pdf中生成表格的方法

    java在pdf中生成表格的方法

    這篇文章主要介紹了java在pdf中生成表格的方法,需要的朋友可以參考下
    2015-11-11
  • Java字符串轉(zhuǎn)時間簡單示例代碼

    Java字符串轉(zhuǎn)時間簡單示例代碼

    這篇文章主要給大家介紹了關(guān)于Java字符串轉(zhuǎn)時間的相關(guān)資料,在Java中字符和字符串常常需要相互轉(zhuǎn)化,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • Java使用枚舉替代if/else和switch-case語句的實(shí)踐

    Java使用枚舉替代if/else和switch-case語句的實(shí)踐

    在軟件開發(fā)中if-else和switch-case語句經(jīng)常被用來處理不同的條件分支,但在大型項(xiàng)目中,這種做法可能導(dǎo)致代碼可讀性差、維護(hù)困難,這篇文章主要給大家介紹了關(guān)于Java使用枚舉替代if/else和switch-case語句的相關(guān)資料,需要的朋友可以參考下
    2024-09-09
  • 深入淺析Java中的volatile

    深入淺析Java中的volatile

    volatile是Java提供的一種輕量級的同步機(jī)制,在并發(fā)編程中,它也扮演著比較重要的角色.這篇文章主要介紹了深入淺析Java中的volatile,需要的朋友可以參考下
    2017-03-03
  • Spring之@DependsOn注解詳細(xì)解析

    Spring之@DependsOn注解詳細(xì)解析

    這篇文章主要介紹了Spring之@DependsOn注解詳細(xì)解析,@DependsOn注解是Spring中提供的一個指定Spring創(chuàng)建Bean的依賴順序的注解,需要的朋友可以參考下
    2024-01-01
  • MVC頁面之間參數(shù)傳遞實(shí)現(xiàn)過程圖解

    MVC頁面之間參數(shù)傳遞實(shí)現(xiàn)過程圖解

    這篇文章主要介紹了MVC頁面之間參數(shù)傳遞實(shí)現(xiàn)過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Java應(yīng)用注冊成Windows服務(wù)實(shí)現(xiàn)自啟的教程詳解

    Java應(yīng)用注冊成Windows服務(wù)實(shí)現(xiàn)自啟的教程詳解

    這篇文章主要給大家介紹了Java應(yīng)用注冊成Windows服務(wù)實(shí)現(xiàn)自啟的教程,文中有詳細(xì)的代碼示例和圖文講解供大家參考,具有一定的參考價值,需要的朋友可以參考下
    2024-02-02
  • Java中的Phaser使用詳解

    Java中的Phaser使用詳解

    這篇文章主要介紹了Java中的Phaser使用詳解,與其他障礙不同,注冊在phaser上進(jìn)行同步的parties數(shù)量可能會隨時間變化,任務(wù)可以隨時進(jìn)行注冊,需要的朋友可以參考下
    2023-11-11
  • Spark Streaming算子開發(fā)實(shí)例

    Spark Streaming算子開發(fā)實(shí)例

    這篇文章主要介紹了Spark Streaming算子開發(fā)實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • idea生成類注釋和方法注釋的正確方法(推薦)

    idea生成類注釋和方法注釋的正確方法(推薦)

    這篇文章主要介紹了idea生成類注釋和方法注釋的正確方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11

最新評論