今天我們講一下在 Java 中驗證碼的使用。
驗證碼生成
本效果是利用easy-captcha工具包實現,首先需要添加相關依賴到pom.xml中,代碼如下:
< dependency >
< groupId >com.github.whvcse< /groupId >
< artifactId >easy-captcha< /artifactId >
< version >1.6.2< /version >
< /dependency >
驗證碼格式
easy-captcha驗證碼工具支持GIF、中文、算術等類型,分別通過下面幾個實例對象實現:
- SpecCaptcha(PNG類型的靜態圖片驗證碼)
- GifCaptcha(Gif類型的圖片驗證碼)
- ChineseCaptcha(GIF類型中文圖片驗證碼)
- ArithmeticCaptcha(算術類型的圖片驗證碼)
字符類型分為以下幾種:
- TYPE_DEFAULT:數字和字母混合
- TYPEONLYNUMBER:純數字
- TYPEONLYCHAR:純字母
- TYPEONLYUPPER:純大寫字母
- TYPEONLYLOWER:純小寫字母
- TYPENUMAND_UPPER:數字和大寫字母混合
后端邏輯的實現
package com.yanx.controller;
import com.wf.captcha.SpecCaptcha;
import com.wf.captcha.base.Captcha;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.thymeleaf.util.StringUtils;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@Controller
public class KapchaController {
@GetMapping("/kaptcha")
public void defaultKaptcha(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws IOException {
httpServletResponse.setHeader("Cache-Control","no-store");
httpServletResponse.setHeader("Pragma","no-cache");
httpServletResponse.setDateHeader("Expires",0);
httpServletResponse.setContentType("image/gif");
//三個參數分別為寬、高、位數
SpecCaptcha captcha=new SpecCaptcha(75,30,4);
//設置類型為數字和字母混合
captcha.setCharType(Captcha.TYPE_DEFAULT);
//設置字體
captcha.setCharType(Captcha.FONT_9);
//驗證碼存入session
httpServletRequest.getSession().setAttribute("verifyCode",captcha.text().toLowerCase());
//輸出圖片流
captcha.out(httpServletResponse.getOutputStream());
}
}
這里控制器新增了defaultKaptcha()方法,該方法所攔截處理的路徑為/kaptcha
前端邏輯的實現
在static目錄中新建kaptcha.html頁面,代碼如下:
< !DOCTYPE html >
< html lang="en" >
< head >
< meta charset="UTF-8" >
< title >驗證碼< /title >
< /head >
< body >
< img src="/kaptcha" onclick="this.src='/kaptcha?t=new Date()'" >
< /body >
< /html >
訪問后端驗證碼路徑/kaptcha,驗證碼為圖片形式。onclick方法為點擊該標簽時可以動態切換顯示驗證碼。
啟動Spring Boot項目,打開瀏覽器輸入地址:
http://localhost:8080/kaptcha.html
效果如下:
驗證碼驗證
后端代碼
package com.yanx.controller;
import com.wf.captcha.SpecCaptcha;
import com.wf.captcha.base.Captcha;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.thymeleaf.util.StringUtils;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@Controller
public class KapchaController {
@GetMapping("/kaptcha")
public void defaultKaptcha(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws IOException {
httpServletResponse.setHeader("Cache-Control","no-store");
httpServletResponse.setHeader("Pragma","no-cache");
httpServletResponse.setDateHeader("Expires",0);
httpServletResponse.setContentType("image/gif");
//三個參數分別為寬、高、位數
SpecCaptcha captcha=new SpecCaptcha(75,30,4);
//設置類型為數字和字母混合
captcha.setCharType(Captcha.TYPE_DEFAULT);
//設置字體
captcha.setCharType(Captcha.FONT_9);
//驗證碼存入session
httpServletRequest.getSession().setAttribute("verifyCode",captcha.text().toLowerCase());
//輸出圖片流
captcha.out(httpServletResponse.getOutputStream());
}
@GetMapping("/verify")
@ResponseBody
public String verify(@RequestParam("code") String code, HttpSession session){
if(StringUtils.isEmpty(code)){
return "驗證碼不能為空";
}
String kapchaCode = session.getAttribute("verifyCode")+"";
if(StringUtils.isEmpty(kapchaCode)||!code.toLowerCase().equals(kapchaCode)){
return "驗證碼輸入錯誤";
}
return "驗證成功";
}
}
前端代碼
< !DOCTYPE html >
< html lang="en" >
< head >
< meta charset="UTF-8" >
< title >驗證碼驗證< /title >
< /head >
< body >
< img src="/kaptcha" onclick="this.src='/kaptcha?d=new Date()'" >
< br >
< input type="text" maxlength="5" id="code" placeholder="請輸入驗證碼"/ >
< button id="verify" >驗證< /button >
< br/ >
< p id="verifyResult" >< /p >
< /body >
< script src="https://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){
$('#verifyResult').html(result);
},
error:function(){
alert('請求失敗');
},
});
});
});
< /script >
< /html >
效果
結束語
生成驗證碼功能還是比較常用的,所以記錄整理一下,方便以后回顧,如果有幫到你們的地方倍感榮幸,有路過的大佬還望不吝雅教!
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
JAVA
+關注
關注
19文章
2974瀏覽量
105146 -
瀏覽器
+關注
關注
1文章
1035瀏覽量
35534 -
代碼
+關注
關注
30文章
4826瀏覽量
69052 -
驗證碼
+關注
關注
2文章
20瀏覽量
4734
發布評論請先 登錄
相關推薦
10種意想不到的驗證碼風格設計
simpleCaptcha玩具驗證碼,選一個吧。7. slideLock拖動滾動條來解鎖吧。8. Captcha PHP動畫驗證碼。9. NuCaptcha輸入flash視頻中的紅字母就對了。10.
發表于 05-05 14:03
java圖形驗證碼生成的設計實現
;/Kaptcha</url-pattern></servlet-mapping>html中添加驗證碼標簽,并綁定javascript事件:<
發表于 10-21 14:42
打碼平臺是如何高效的破解市面上各家驗證碼平臺的各種形式驗證碼的?
點選類驗證碼。所以機器破解的主要方向是通過識別圖片中的相關驗證要素來進行破解,例如識別滑動驗證碼的缺口,點選驗證碼中的文字要素和數字要素,其
發表于 11-01 15:21
基于加密短信驗證碼的移動安全支付解決方案
針對移動支付過程中支付驗證碼容易泄露的問題,提出了基于加密短信息驗證碼的雙因素移動支付系統方案。該方案基于公開密鑰系統,使用公鑰基礎設施/認證機構( PKI/CA)的認證方法進行服務器與客戶端的在線
發表于 11-29 14:40
?0次下載
多樣變換的手寫驗證碼自動識別算法
研究驗證碼自動識別技術可以進一步提升人識別驗證碼的可讀性,增強機器識別的難度,從而提高網絡安全性。針對目前提出的驗證碼識別方法基本都是采用光學字符識別(OCR)方法對機器寫的標準字符進行識別,本文
發表于 12-20 14:14
?0次下載
以一個真實網站的驗證碼為例,實現了基于一下KNN的驗證碼識別
很多網站登錄都需要輸入驗證碼,如果要實現自動登錄就不可避免的要識別驗證碼。本文以一個真實網站的驗證碼為例,實現了基于一下KNN的驗證碼識別。
驗證碼層出不窮?試試這個自動跳過驗證碼的工具
目前網絡上越來越多使用驗證碼了,驗證碼的本意是阻止機器刷流量擠占服務器資源,這本來無可厚非;但是驗證碼已經變得越來越過分,別說機器人了,連人也經常沒法辨認!這就相當煩了,特別是被廣泛使用更多
驗證碼太麻煩,自動跳過驗證碼神器試一試
目前網絡上越來越多使用驗證碼了,驗證碼的本意是阻止機器刷流量擠占服務器資源,這本來無可厚非;但是驗證碼已經變得越來越過分,別說機器人了,連人也經常沒法辨認! 這就相當煩了,特別是被廣泛使用更多
帶帶弟弟OCR通用驗證碼識別SDK免費開源版
在使用爬蟲登錄網站的時候,經常輸入用戶名和密碼后會遇到驗證碼,簡單一點的有字母驗證碼,復雜一點的有滑塊驗證碼,點選文章和點選圖片驗證碼。這些都是爬蟲
一個短信驗證碼爆破重置
以前倒是遇到過不少四位數驗證碼爆破的,但是這種可以結合短信遍歷,一個短信驗證碼只能驗證三次的,最后能成功利用的還是第一次遇到,關鍵還是這里不存在圖片驗證碼或者行為
SpringBoot分布式驗證碼登錄方案
傳統的項目大都是基于session交互的,前后端都在一個項目里面,比如傳統的SSH項目或者一些JSP系統,當前端頁面觸發到獲取驗證碼請求,可以將驗證碼里面的信息存在上下文中,所以登錄的時候只需要 用戶名、密碼、驗證碼即可。
評論