欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SSM 實現(xiàn)登錄驗證碼功能(附源碼)

 更新時間:2018年12月07日 11:12:03   作者:csdn_小東  
這篇文章主要介紹了SSM 實現(xiàn)登錄驗證碼功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

如果想用框架來實現(xiàn)驗證碼,可以看我的另外一篇:

Kaptcha 框架的使用很簡單的。新手必備。

http://www.dbjr.com.cn/article/152260.htm

一、效果圖

二、實現(xiàn)代碼

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

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 {
 //設置相應類型,告訴瀏覽器輸出的內(nèi)容為圖片
  response.setContentType("image/jpeg");
  //設置響應頭信息,告訴瀏覽器不要緩存此內(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" style="height:43px;cursor:pointer;" onclick="this.src=this.src+'?'">

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

總結

以上所述是小編給大家介紹的SSM 實現(xiàn)登錄驗證碼功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • Maven插件的安裝及使用

    Maven插件的安裝及使用

    這篇文章主要介紹了Maven插件的安裝及使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • 詳解Java解析XML的四種方法

    詳解Java解析XML的四種方法

    本篇文章主要介紹了java解析XML的幾種方式,XML現(xiàn)在已經(jīng)成為一種通用的數(shù)據(jù)交換格式,給數(shù)據(jù)集成與交互提供了方便,有需要的可以了解一下。
    2016-11-11
  • Java中for循環(huán)的執(zhí)行過程分析

    Java中for循環(huán)的執(zhí)行過程分析

    這篇文章主要介紹了Java中for循環(huán)的執(zhí)行過程,實例分析了for循環(huán)的執(zhí)行原理與順序,對于深入理解Java具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • SpringBoot 整合jdbc和mybatis的方法

    SpringBoot 整合jdbc和mybatis的方法

    該文章主要為記錄如何在SpringBoot項目中整合JDBC和MyBatis,在整合中我會使用簡單的用法和測試用例,感興趣的朋友跟隨小編一起看看吧
    2019-11-11
  • Java將字符串String轉(zhuǎn)換為整型Int的兩種方式

    Java將字符串String轉(zhuǎn)換為整型Int的兩種方式

    這篇文章主要介紹了Java如何將字符串String轉(zhuǎn)換為整型Int,在 Java 中要將 String 類型轉(zhuǎn)化為 int 類型時,需要使用 Integer 類中的 parseInt() 方法或者 valueOf() 方法進行轉(zhuǎn)換,本文通過實例代碼給大家詳細講解,需要的朋友可以參考下
    2023-04-04
  • SpringBoot Aop 詳解和多種使用場景解析

    SpringBoot Aop 詳解和多種使用場景解析

    aop面向切面編程,是編程中一個很重要的思想本篇文章主要介紹的是SpringBoot切面Aop的使用和案例,對SpringBoot Aop相關知識感興趣的朋友跟隨小編一起看看吧
    2021-08-08
  • SpringBoot添加SSL證書,開啟HTTPS方式(單向認證服務端)

    SpringBoot添加SSL證書,開啟HTTPS方式(單向認證服務端)

    這篇文章主要介紹了SpringBoot添加SSL證書,開啟HTTPS方式(單向認證服務端),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 淺談SpringBoot資源初始化加載的幾種方式

    淺談SpringBoot資源初始化加載的幾種方式

    在平時的業(yè)務模塊開發(fā)過程中,難免會需要做一些全局的任務、緩存、線程等等的初始化工作,那么如何解決這個問題呢?本文就來介紹一下,感興趣的可以了解一下
    2021-07-07
  • Java多態(tài)到底都有啥好處

    Java多態(tài)到底都有啥好處

    Java中的多態(tài)性有兩種類型:編譯時多態(tài)(靜態(tài)綁定)和運行時多態(tài)(動態(tài)綁定)。方法重載是靜態(tài)多態(tài)的一個例子,而方法重寫是動態(tài)多態(tài)的一個例子,接下來通過本文給大家分享Java多態(tài)到底教了我干啥?有啥好處,一起了解下吧
    2021-05-05
  • Java實現(xiàn)簡單的斗地主游戲

    Java實現(xiàn)簡單的斗地主游戲

    這篇文章主要為大家詳細介紹了Java實現(xiàn)簡單的斗地主游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評論