真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

springboot結合kaptcha怎么實現(xiàn)一個驗證碼登陸功能

本篇文章給大家分享的是有關spring boot結合kaptcha怎么實現(xiàn)一個驗證碼登陸功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

襄垣ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!

引入kaptcha所需要的jar包,我這里用的是maven

   
   com.github.penggle 
   kaptcha 
   2.3.2 
    
    
     
     javax.servlet-api 
     javax.servlet 
     
    
   

去除包中自帶的servlet包。在我個人的理解中springboot就是javaconfig和注解搭建起來的輕型的微架構。

下面是kapcha的javaconfig

@Configuration 
public class CaptchaConfig { 
  
 
 @Bean(name="captchaProducer") 
 public DefaultKaptcha getKaptchaBean(){ 
  DefaultKaptcha defaultKaptcha=new DefaultKaptcha(); 
  Properties properties=new Properties(); 
  properties.setProperty("kaptcha.border", "yes"); 
  properties.setProperty("kaptcha.border.color", "105,179,90"); 
  properties.setProperty("kaptcha.textproducer.font.color", "blue"); 
  properties.setProperty("kaptcha.image.width", "125"); 
  properties.setProperty("kaptcha.image.height", "45"); 
  properties.setProperty("kaptcha.session.key", "code"); 
  properties.setProperty("kaptcha.textproducer.char.length", "4"); 
  properties.setProperty("kaptcha.textproducer.font.names", "宋體,楷體,微軟雅黑");   
  Config config=new Config(properties); 
  defaultKaptcha.setConfig(config); 
  return defaultKaptcha; 
 } 
} 

這里的的katcha的javaconfig相當于springmvc中的bean配置,下面給是一個針對上面javaconfig的springmvc的bean示例,供參考

 
   
    
     
      
      yes 
      105,179,90 
      blue 
      125 
      45 
      45 
      code 
      4 
      宋體,楷體,微軟雅黑 
      
     
    
   
  

其中構造方法中的屬性參數(shù)可以根據(jù)自己的需求來設置。

配置文件已經(jīng)配好,那么如何獲取自己的二維碼呢,我的理解是畫布的概念,然后將生成的四位的驗證碼生成對應的畫布,然后讓結果write出去。

代碼如下:

@RequestMapping(value = "/captcha-image") 
 public ModelAndView getKaptchaImage(HttpServletRequest request, 
   HttpServletResponse response) throws Exception { 
  response.setDateHeader("Expires", 0); 
  response.setHeader("Cache-Control", 
    "no-store, no-cache, must-revalidate"); 
  response.addHeader("Cache-Control", "post-check=0, pre-check=0"); 
  response.setHeader("Pragma", "no-cache"); 
  response.setContentType("image/jpeg"); 
 
  String capText = captchaProducer.createText(); 
  System.out.println("capText: " + capText); 
 
  try { 
   String uuid=UUIDUtils.getUUID32().trim().toString();    
   redisTemplate.opsForValue().set(uuid, capText,60*5,TimeUnit.SECONDS); 
   Cookie cookie = new Cookie("captchaCode",uuid); 
   response.addCookie(cookie); 
  } catch (Exception e) { 
   e.printStackTrace(); 
  } 
 
   
 
  BufferedImage bi = captchaProducer.createImage(capText); 
  ServletOutputStream out = response.getOutputStream(); 
  ImageIO.write(bi, "jpg", out); 
  try { 
   out.flush(); 
  } finally { 
   out.close(); 
  } 
  return null; 
 } 

如上面的代碼,在用戶登錄的時候使用驗證碼以及cooike中的captchacode來實現(xiàn)唯一性驗證,開始的時候我考慮到放到session中,當時想了下,感覺這不科學啊,比如講captchacode放到session中,這時候驗證碼是一個,后來另一個用戶再登陸,前一個用戶還在登陸中,這時候會出現(xiàn)一系列的問題。這里使用cookie和redis,來應對用戶的并發(fā)登陸驗證。

頁面使用也比較簡單如下:

點擊更換

更換的話加一個click事件,然后清空以前在redis中對應的緩存數(shù)據(jù);或者在獲取驗證碼的時候,設置生存周期。

以上就是spring boot結合kaptcha怎么實現(xiàn)一個驗證碼登陸功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


標題名稱:springboot結合kaptcha怎么實現(xiàn)一個驗證碼登陸功能
分享網(wǎng)址:http://weahome.cn/article/pdghcd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部