国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

springboot驗證碼生成及驗證功能

這篇具有很好參考價值的文章主要介紹了springboot驗證碼生成及驗證功能。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

1.easy-captcha工具包

生成驗證碼的方式有許多種,這里選擇的是easy-captcha工具包。
github開原地址為:easy-captcha工具包
其支持Java圖形驗證碼,支持gif、中文、算術(shù)等類型,可用于Java Web、JavaSE等項目。

2添加依賴

首先需要將easy-captcha的依賴配置文件增加到pom.xml文件中。
開源項目中已經(jīng)寫好了導(dǎo)入依賴語句復(fù)制粘貼過去即可。
springboot驗證碼生成及驗證功能

   <dependency>
      <groupId>com.github.whvcse</groupId>
      <artifactId>easy-captcha</artifactId>
      <version>1.6.2</version>
   </dependency>

3.驗證碼字符類型

springboot驗證碼生成及驗證功能
使用方法:

//生成驗證碼對象
SpecCaptcha captcha = new SpecCaptcha(130, 48, 5);
//設(shè)置驗證碼的字符類型
captcha.setCharType(Captcha.TYPE_ONLY_NUMBER);

4.字體設(shè)置

springboot驗證碼生成及驗證功能
如果不想使用內(nèi)置字體也可以使用系統(tǒng)字體。使用方法如下:

//生成驗證碼對象
SpecCaptcha captcha = new SpecCaptcha(130, 48, 5);

// 設(shè)置內(nèi)置字體
captcha.setFont(Captcha.FONT_1); 

// 設(shè)置系統(tǒng)字體
captcha.setFont(new Font("楷體", Font.PLAIN, 28)); 

5驗證碼圖片輸出

這里可以選擇輸出為文件流,這是比較常見的處理方式。當(dāng)然,也有一些Web項目會使用base64編碼的圖片。這兩種方式easy-captcha都支持。
base64編碼的輸出方法如下所示:

SpecCaptcha specCaptcha = new SpecCaptcha(130, 48, 5);
specCaptcha.toBase64();

// 如果不想要base64的頭部data:image/png;base64,
specCaptcha.toBase64("");  // 加一個空的參數(shù)即可

輸出到磁盤上的方法如下所示:

FileOutputStream outputStream = new FileOutputStream(new File("C:/captcha.png"))
SpecCaptcha specCaptcha = new SpecCaptcha(130, 48, 5);
specCaptcha.out(outputStream);

該段代碼為生成一張圖片并保存到磁盤目錄中,這里可以使用easy-captcha工具自帶的out()方法輸出。而在開發(fā)Web項目時,則會使用Response對象的輸出流進(jìn)行驗證碼的輸出。

6.生成并顯示驗證碼

6.1后端

在controller包中新建KaptchaController類,就可以新建一個方法。在方法里使用GifCaptcha可以生成一個PNG類型的驗證碼對象,并以圖片流的方式輸出到前端以供顯示,代碼如下所示:

@Controller
public class KaptchaController {
    @GetMapping("/kaptcha")
    public void defaultKaptcha(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception{
        httpServletResponse.setHeader("Cache-Control","no-store");
        httpServletResponse.setHeader("Pragma","no-cache");
        httpServletResponse.setDateHeader("Expires",0);
        httpServletResponse.setContentType("image/gif");

        //生成驗證碼對象,三個參數(shù)分別是寬、高、位數(shù)
        SpecCaptcha captcha = new SpecCaptcha(130, 48, 5);
        //設(shè)置驗證碼的字符類型為數(shù)字和字母混合
        captcha.setCharType(Captcha.TYPE_DEFAULT);
        // 設(shè)置內(nèi)置字體
        captcha.setCharType(Captcha.FONT_1);
        //驗證碼存入session
        httpServletRequest.getSession().setAttribute("verifyCode",captcha.text().toLowerCase());
        //輸出圖片流
        captcha.out(httpServletResponse.getOutputStream());
    }
}

這里在控制器中新增了defaultKaptcha()方法,該方法所攔截處理的路徑為/kaptcha。在前端訪問該路徑后就可以接收一個圖片流并顯示在瀏覽器頁面上。

6.2前端

在static目錄中新建kaptcha.html頁面,在該頁面中顯示驗證碼,代碼如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>驗證碼顯示</title>
</head>
<body>
<img src="/kaptcha" onclick="this.src='/kaptcha?d='+new Date()*1" />
</body>
</html>

首先訪問后端驗證碼路徑/kaptcha,由于驗證碼是圖片形式,所以將其顯示在img標(biāo)簽中。然后定義onclick方法,在點擊該img標(biāo)簽時可以動態(tài)切換顯示一個新的驗證碼。點擊時訪問的路徑為’/kaptcha?d='+new Date()*1,即原來的驗證碼路徑后面帶上一個時間戳參數(shù)d。時間戳是會變化的,所以每次點擊都會是一個與之前不同的請求。如果不這樣處理的話,由于瀏覽器的緩存機(jī)制,在點擊刷新驗證碼后可能不會重新發(fā)送請求,將導(dǎo)致在一段時間內(nèi)一直顯示同一張驗證碼圖片。
在編碼完成后,啟動Spring Boot項目。在啟動成功后打開瀏覽器并輸入驗證碼顯示的測試頁面地址

http://localhost:8080/kaptcha

效果如下:
springboot驗證碼生成及驗證功能

7 驗證碼的輸入驗證

一般的做法是在后端生成驗證碼后,首先對當(dāng)前生成的驗證碼內(nèi)容進(jìn)行保存,可以選擇保存在session對象中,或者保存在緩存中,或者保存在數(shù)據(jù)庫中。然后,返回驗證碼圖片并顯示到前端頁面。用戶在識別驗證碼后,在頁面對應(yīng)的輸入框中填寫驗證碼并向后端發(fā)送請求,后端在接到請求后會對用戶輸入的驗證碼進(jìn)行驗證。如果用戶輸入的驗證碼與之前保存的驗證碼不相等的話,則返回“驗證碼錯誤”的提示消息且不會進(jìn)行后續(xù)的流程,只有驗證成功才會繼續(xù)后續(xù)的流程。

7.1后端

在KaptchaController類中新增verify()方法,代碼如下所示:

    public String verify(@RequestParam("code") String code, HttpSession session){
        if (!StringUtils.hasLength(code)){
            return "驗證碼不能為空";
        }
        String kaptchaCode = session.getAttribute("verifyCode")+"";
        if (!StringUtils.hasLength(kaptchaCode)||!code.toLowerCase().equals(kaptchaCode)){
            return "驗證碼錯誤";
        }
        return "驗證成功";
    }

該方法所攔截處理的路徑為/verify,請求參數(shù)為code,即用戶輸入的驗證碼。在進(jìn)行基本的非空驗證后,與之前保存在session中的verifyCode值進(jìn)行比較,如果兩個字符串不相等則返回“驗證碼錯誤”的提示,二者相同則返回“驗證碼成功”的提示。

7.2前端

在static目錄中新建verify.html,該頁面會顯示驗證碼,同時也包含供用戶輸入驗證碼的輸入框和提交按鈕,代碼如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>驗證碼測試</title>
</head>
<body>
<img src="/kaptcha" onclick="this.src='/kaptcha?d='+new Date()*1" />
<br>
<input type="text" maxlength="5" id="code" placeholder="請輸入驗證碼" />
<button id="verify">驗證</button>
<br>
<p id="verifyResult">
</p>
</body>
<!--jqGrid依賴jQuery,因此需要先引入jquery.min.js文件,下方地址為字節(jié)跳動提供的cdn地址-->
<script src="http://s3.pstatp.com/cdn/expire-1-M/jquery/3.3.1/jquery.min.js"></script>
<script type="text/javascript">
    $(function () {
    //驗證按鈕的點擊事件
        $('#verify').click(function () {
            var code = $('#code').val();
            $.ajax({
                type: 'GET',//方法類型
                url: '/verify?code='+code,
                success: function (result) {
                //將驗證結(jié)果顯示在p標(biāo)簽中
                    $('#verifyResult').html(result);
                },
                error:function () {
                    alert('請求失敗');
                },
            });
        });
    });
</script>
</html>

用戶識別顯示在頁面上的驗證碼后,就可以在input框中輸入驗證碼并點擊“驗證”按鈕。在JS代碼中已經(jīng)定義了“驗證”按鈕的點擊事件,一旦點擊,就會獲取用戶在輸入框中輸入的內(nèi)容,并將其作為請求參數(shù)向后端發(fā)送請求,驗證用戶輸入的驗證碼是否正確,后端在處理完成后會返回處理結(jié)果,拿到處理結(jié)果就顯示在id為verifyResult的p標(biāo)簽中。
springboot驗證碼生成及驗證功能文章來源地址http://www.zghlxwxcb.cn/news/detail-413841.html

到了這里,關(guān)于springboot驗證碼生成及驗證功能的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Springboot3整合使用ja-captcha行為驗證碼解決方案

    Springboot3整合使用ja-captcha行為驗證碼解決方案

    截止到目前(2023-04-20),Springboot最新穩(wěn)定版本已經(jīng)迭代到3.0.5,而我們項目中使用的行為驗證碼框架 aj-captcha 還沒有適配Springboot3,碼云上類似的請求也沒有得到過回應(yīng),于是決定自己動手適配一下,研究下來發(fā)現(xiàn)適配3.x并沒有那么難,這里記錄一下適配過程,希望能幫到他人

    2023年04月20日
    瀏覽(98)
  • 爬蟲突破驗證碼技術(shù) - 2Captcha

    爬蟲突破驗證碼技術(shù) - 2Captcha

    驗證碼(CAPTCHA),全稱為\\\"Completely Automated Public Turing test to tell Computers and Humans Apart\\\",是一種區(qū)分用戶是計算機(jī)還是人的公共全自動程序。最初,驗證碼主要是一些混雜字母和數(shù)字的圖片,但隨著技術(shù)的發(fā)展,出現(xiàn)了更多種類的驗證碼,例如reCAPTCHA、GeeTest拼圖驗證碼、hCaptc

    2024年02月16日
    瀏覽(19)
  • 爬蟲識別驗證碼技術(shù) - 2Captcha

    爬蟲識別驗證碼技術(shù) - 2Captcha

    驗證碼(CAPTCHA),全稱為\\\"Completely Automated Public Turing test to tell Computers and Humans Apart\\\",是一種區(qū)分用戶是計算機(jī)還是人的公共全自動程序。最初,驗證碼主要是一些混雜字母和數(shù)字的圖片,但隨著技術(shù)的發(fā)展,出現(xiàn)了更多種類的驗證碼,例如reCAPTCHA、GeeTest拼圖驗證碼、hCaptc

    2024年02月16日
    瀏覽(26)
  • Selenium+2Captcha 自動化+驗證碼識別實戰(zhàn)

    Selenium+2Captcha 自動化+驗證碼識別實戰(zhàn)

    本文深入探討了使用Selenium庫進(jìn)行網(wǎng)頁自動化操作,并結(jié)合2Captcha服務(wù)實現(xiàn)ReCAPTCHA驗證碼的破解。內(nèi)容涵蓋Selenium的基礎(chǔ)知識、驗證碼的分類、2Captcha服務(wù)的使用,以及通過實例進(jìn)行的詳細(xì)講解,最后對實踐進(jìn)行總結(jié)和優(yōu)化思考,為讀者提供了一條完整的驗證碼破解實踐路線圖

    2024年02月14日
    瀏覽(23)
  • burpsuite安裝插件captcha-killer識別驗證碼

    burpsuite安裝插件captcha-killer識別驗證碼

    我安裝的是burpsuite v.2021版本,于2020年后,使用的captcha-killer鏈接地址如下: (burp版本為2020年前的可查看文末鏈接1) GitHub - Ta0ing/captcha-killer-java8 https://github.com/Ta0ing/captcha-killer-java8 下載zip文件并解壓文件 打開burpsuite,Extender擴(kuò)展 - Add添加.jar文件 -Select file選擇文件 - Next -

    2023年04月08日
    瀏覽(33)
  • Brup+Captcha-killer+ddddocr實現(xiàn)驗證碼識別

    Brup+Captcha-killer+ddddocr實現(xiàn)驗證碼識別

    實驗前準(zhǔn)備:Burp(2020以后的版本jdk11) captcha-killer(burp插件針對不同版本的burp存在不同的版本) ddddocr(開源驗證碼識別接口最新版已支持python3.10版本) 項目地址:https://github.com/f0ng/captcha-killer-modified https://github.com/sml2h3/ddddocr burp的安裝和破解在此不做贅述,首先我們到上面

    2023年04月09日
    瀏覽(39)
  • 對有驗證碼的后臺網(wǎng)頁進(jìn)行爆破-captcha-killer-modified

    對有驗證碼的后臺網(wǎng)頁進(jìn)行爆破-captcha-killer-modified

    實例:以pikachu靶場為目標(biāo) 攻擊目標(biāo)url:http://xxxx/pikachu-master/vul/burteforce/bf_server.php(xxxx為自己的靶機(jī)地址,我的就是127.0.0.1) 攻擊目標(biāo)的驗證碼圖片接口的url:http://127.0.0.1/pikachu-master/inc/showvcode.php 通過burp工具抓包(設(shè)置burp代理之后,點擊login抓包包) 右擊選擇發(fā)送到captcha

    2024年02月08日
    瀏覽(20)
  • uni-app使用uniCloud實現(xiàn)圖形驗證碼(uni-captcha)

    uni-app使用uniCloud實現(xiàn)圖形驗證碼(uni-captcha)

    uniCloud 是 DCloud 聯(lián)合阿里云、騰訊云,為開發(fā)者提供的基于 serverless 模式和 js 編程的云開發(fā)平臺。 官方文檔:https://uniapp.dcloud.net.cn/uniCloud/uni-captcha.html 下載地址:https://ext.dcloud.net.cn/plugin?id=4048 GitCode 倉庫:https://gitee.com/dcloud/uni-captcha 圖形驗證碼主要起到人機(jī)校驗或其他限制

    2024年02月08日
    瀏覽(19)
  • [golang gin框架] 40.Gin商城項目-微服務(wù)實戰(zhàn)之Captcha驗證碼微服務(wù)

    [golang gin框架] 40.Gin商城項目-微服務(wù)實戰(zhàn)之Captcha驗證碼微服務(wù)

    本次內(nèi)容需要 gin框架基礎(chǔ)知識, golang微服務(wù)基礎(chǔ)知識才能更好理解 在前面,講解了微服務(wù)的架構(gòu)等,這里,來講解前面商城項目的 Captcha驗證碼 微服務(wù) ,captcha驗證碼功能在前臺,后端 都要用到 ,可以把它 抽離出來 ,做成微服務(wù)功能 編輯 這個驗證碼功能封裝代碼captcha.go如下: 把這個

    2024年02月16日
    瀏覽(30)
  • SpringBoot+Vue 實現(xiàn)圖片驗證碼功能需求

    SpringBoot+Vue 實現(xiàn)圖片驗證碼功能需求

    文章底部有個人公眾號: 熱愛技術(shù)的小鄭 。主要分享開發(fā)知識、有興趣的可以關(guān)注一下。為何分享? 踩過的坑沒必要讓別人在再踩,自己復(fù)盤也能加深記憶。利己利人、所謂雙贏。 寫過驗證碼保存到Redis中的需求開發(fā)、也寫過驗證碼調(diào)用第三方接口直接發(fā)送到手機(jī)的需求開

    2024年02月14日
    瀏覽(22)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包