Springboot實現(xiàn)驗證碼登錄

本文實例為大家分享了Springboot實現(xiàn)驗證碼登錄的具體代碼,供大家參考,具體內容如下

10年積累的成都網站制作、網站設計經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站設計后付款的網站建設流程,更有麗江免費網站建設讓你可以放心的選擇與我們合作。

因為在項目中需要使用到驗證碼,我總結一下在項目中如何快速解決項目需求~驗證碼,下面推薦給大家速上手驗證碼的例子。

一、編寫驗證碼工具類

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;

import javax.imageio.ImageIO;

/**
 * @author zct
 * @date 2018年2月6日
 * @param
 * @desc 圖形驗證碼生成
 *
 */
public class VerifyUtil {
 // 驗證碼字符集
 private static final char[] chars = {
  '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
  'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
  'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
  'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
 // 字符數(shù)量
 private static final int SIZE = 4;
 // 干擾線數(shù)量
 private static final int LINES = 5;
 // 寬度
 private static final int WIDTH = 80;
 // 高度
 private static final int HEIGHT = 40;
 // 字體大小
 private static final int FONT_SIZE = 30;

 /**
 * 生成隨機驗證碼及圖片
 * Object[0]:驗證碼字符串;
 * Object[1]:驗證碼圖片。
 */
 public static Object[] createImage() {
 StringBuffer sb = new StringBuffer();
 // 1.創(chuàng)建空白圖片
 BufferedImage image = new BufferedImage(
  WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
 // 2.獲取圖片畫筆
 Graphics graphic = image.getGraphics();
 // 3.設置畫筆顏色
 graphic.setColor(Color.LIGHT_GRAY);
 // 4.繪制矩形背景
 graphic.fillRect(0, 0, WIDTH, HEIGHT);
 // 5.畫隨機字符
 Random ran = new Random();
 for (int i = 0; i <SIZE; i++) {
  // 取隨機字符索引
  int n = ran.nextInt(chars.length);
  // 設置隨機顏色
  graphic.setColor(getRandomColor());
  // 設置字體大小
  graphic.setFont(new Font(
   null, Font.BOLD + Font.ITALIC, FONT_SIZE));
  // 畫字符
  graphic.drawString(
   chars[n] + "", i * WIDTH / SIZE, HEIGHT*2/3);
  // 記錄字符
  sb.append(chars[n]);
 }
 // 6.畫干擾線
 for (int i = 0; i < LINES; i++) {
  // 設置隨機顏色
  graphic.setColor(getRandomColor());
  // 隨機畫線
  graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT),
   ran.nextInt(WIDTH), ran.nextInt(HEIGHT));
 }
 // 7.返回驗證碼和圖片
 return new Object[]{sb.toString(), image};
 }

 /**
 * 隨機取色
 */
 public static Color getRandomColor() {
 Random ran = new Random();
 Color color = new Color(ran.nextInt(256),
  ran.nextInt(256), ran.nextInt(256));
 return color;
 }
}

二、controller層使用

驗證用戶名和密碼和驗證碼一致

 /**
 * 登錄入口
 *
 * @param username 用戶名
 * @param password 密碼
 * @param code 驗證碼
 * @param response 回調json數(shù)據(jù) 成功返回200,失敗返回500
 */
 @ApiOperation("登錄")
 @PostMapping("/login")
 public void adminLoginByPasswword(@ApiParam("用戶名") @RequestParam String username, @ApiParam("密碼") @RequestParam String password, @ApiParam("驗證碼") @RequestParam String code, HttpServletResponse response,HttpServletRequest request) {
 HttpSession session=request.getSession();
 if(session.getAttribute("imageCode")==null){
  renderFail(response, "重新獲取驗證碼");
 }else {
  if(session.getAttribute("imageCode").toString().equalsIgnoreCase(code)){
  Map<String, Object> user = adminService.checkAdminLogin(username, password);
  if (user == null) {
   renderFail(response, "登錄失敗");
  } else {
   renderSuccess(response, "登錄成功");
  }
  }else {
  renderFail(response, "驗證碼錯誤");
  }
 }


 }

這里采用get請求獲取驗證碼,獲取驗證碼的接口如下

@ApiOperation("生成驗證碼")
 @GetMapping("/getcode")
 public void getCode(HttpServletResponse response, HttpServletRequest request) throws Exception{
 HttpSession session=request.getSession();
 //利用圖片工具生成圖片
 //第一個參數(shù)是生成的驗證碼,第二個參數(shù)是生成的圖片
 Object[] objs = VerifyUtil.createImage();
 //將驗證碼存入Session
 session.setAttribute("imageCode",objs[0]);

 //將圖片輸出給瀏覽器
 BufferedImage image = (BufferedImage) objs[1];
 response.setContentType("image/png");
 OutputStream os = response.getOutputStream();
 ImageIO.write(image, "png", os);
 }

三、代碼測試

這里用springboot Swagger2測試

Springboot實現(xiàn)驗證碼登錄

上面是get請求獲取驗證碼,下面是登錄驗證,驗證結果是成功的。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

當前題目:Springboot實現(xiàn)驗證碼登錄
分享路徑:http://muchs.cn/article48/pphiep.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化外貿建站、App設計、微信小程序、企業(yè)建站、域名注冊

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)