溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SSM如何實現(xiàn)登錄驗證碼功能

發(fā)布時間:2021-05-21 10:25:13 來源:億速云 閱讀:1797 作者:小新 欄目:編程語言

小編給大家分享一下SSM如何實現(xiàn)登錄驗證碼功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、效果圖

SSM如何實現(xiàn)登錄驗證碼功能

二、實現(xiàn)代碼

第一步:先建一個 RandomValidateCode.java 作為工具類。把下面的代碼直接復(fù)制粘貼即可。

package com.utils;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class RandomValidateCode {
 public static final String RANDOMCODEKEY = "randomcode_key";//放到session中的key
 private Random random = new Random();
 private String randString = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//隨機產(chǎn)生的字符串
 private int width = 80;//圖片寬
 private int height = 26;//圖片高
 private int lineSize = 40;//干擾線數(shù)量
 private int stringNum = 4;//隨機產(chǎn)生字符數(shù)量
 /**
  * 生成隨機圖片
  */
 public void getRandcode(HttpServletRequest request,
   HttpServletResponse response) {
  HttpSession session = request.getSession();
  //BufferedImage類是具有緩沖區(qū)的Image類,Image類是用于描述圖像信息的類
  BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_BGR);
  //產(chǎn)生Image對象的Graphics對象,改對象可以在圖像上進行各種繪制操作
  Graphics g = image.getGraphics();
  g.fillRect(0, 0, width, height);
  g.setFont(new Font("Times New Roman",Font.ROMAN_BASELINE,18));
  g.setColor(getRandColor(160, 200));
  //繪制干擾線
  for(int i=0;i<=lineSize;i++){
   drowLine(g);
  }
  //繪制隨機字符
  String randomString = "";
  for(int i=1;i<=stringNum;i++){
   randomString=drowString(g,randomString,i);
  }
  session.removeAttribute(RANDOMCODEKEY);
  session.setAttribute(RANDOMCODEKEY, randomString);
  g.dispose();
  try {
   //將內(nèi)存中的圖片通過流動形式輸出到客戶端
   ImageIO.write(image, "JPEG", response.getOutputStream());
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 /*
  * 獲得字體
  */
 private Font getFont(){
  return new Font("Fixedsys",Font.CENTER_BASELINE,18);
 }
 /*
  * 獲得顏色
  */
 private Color getRandColor(int fc,int bc){
  if(fc > 255)
   fc = 255;
  if(bc > 255)
   bc = 255;
  int r = fc + random.nextInt(bc-fc-16);
  int g = fc + random.nextInt(bc-fc-14);
  int b = fc + random.nextInt(bc-fc-18);
  return new Color(r,g,b);
 }
 /*
  * 繪制字符串
  */
 private String drowString(Graphics g,String randomString,int i){
  g.setFont(getFont());
  g.setColor(new Color(random.nextInt(101),random.nextInt(111),random.nextInt(121)));
  String rand = String.valueOf(getRandomString(random.nextInt(randString.length())));
  randomString +=rand;
  g.translate(random.nextInt(3), random.nextInt(3));
  g.drawString(rand, 13*i, 16);
  return randomString;
 }
 /*
  * 繪制干擾線
  */
 private void drowLine(Graphics g){
  int x = random.nextInt(width);
  int y = random.nextInt(height);
  int xl = random.nextInt(13);
  int yl = random.nextInt(15);
  g.drawLine(x, y, x+xl, y+yl);
 }
 /*
  * 獲取隨機的字符
  */
 public String getRandomString(int num){
  return String.valueOf(randString.charAt(num));
 }
}

第二步:在 Controller 類寫前端 UI 的接口

 /**
 * 獲取生成驗證碼顯示到 UI 界面
 * @param request
 * @param response
 * @throws ServletException
 * @throws IOException
 */
 @RequestMapping(value="/checkCode")
 public void checkCode(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
 //設(shè)置相應(yīng)類型,告訴瀏覽器輸出的內(nèi)容為圖片
  response.setContentType("image/jpeg");
  //設(shè)置響應(yīng)頭信息,告訴瀏覽器不要緩存此內(nèi)容
  response.setHeader("pragma", "no-cache");
  response.setHeader("Cache-Control", "no-cache");
  response.setDateHeader("Expire", 0);
  RandomValidateCode randomValidateCode = new RandomValidateCode();
  try {
   randomValidateCode.getRandcode(request, response);//輸出圖片方法
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

第三步:jsp 頁面獲取驗證碼

<img src="checkCode" alt="" width="100" height="32" class="passcode"  onclick="this.src=this.src+'?'">

第四步:我的是在 SSM 環(huán)境下實現(xiàn)的,如果不是的話可以自己改寫下。

以上是“SSM如何實現(xiàn)登錄驗證碼功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

ssm
AI