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

java實現(xiàn)簡單的驗證碼功能

 更新時間:2020年04月23日 15:30:34   作者:踢飛足球  
這篇文章主要為大家詳細介紹了java實現(xiàn)簡單的驗證碼功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近要做一個網(wǎng)站,要求實現(xiàn)驗證碼程序,經(jīng)過不斷調(diào)試,終于成功實現(xiàn)功能。

一、驗證碼生成類

生成驗證碼的話需要用到java的Graphics類庫,畫出一個驗證碼
廢話不多說,直接上代碼

package verificationCode;


import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.awt.image.RenderedImage;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;

import javax.imageio.ImageIO;

public class generateCode {
 private static int width = 150;// 定義圖片的width
 private static int height = 48;// 定義圖片的height
 private static int codeCount = 4;// 定義圖片上顯示驗證碼的個數(shù)
 private static int xx = 25;
 private static int fontHeight = 42;
 private static int codeY = 42;
 private static char[] codeSequence = { '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', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };

 /**
  * 生成一個map集合
  * code為生成的驗證碼
  * codePic為生成的驗證碼BufferedImage對象
  * @return
  */
 public static Map<String,Object> generateCodeAndPic() {
  // 定義圖像buffer
  BufferedImage buffImg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
  // Graphics2D gd = buffImg.createGraphics();
  // Graphics2D gd = (Graphics2D) buffImg.getGraphics();
  Graphics gd = buffImg.getGraphics();
  // 創(chuàng)建一個隨機數(shù)生成器類
  Random random = new Random();
  // 將圖像填充為白色
  gd.setColor(Color.WHITE);
  gd.fillRect(0, 0, width, height);

  // 創(chuàng)建字體,字體的大小應該根據(jù)圖片的高度來定。
  Font font = new Font("Fixedsys", Font.BOLD, fontHeight);
  // 設置字體。
  gd.setFont(font);

  // 畫邊框。
  gd.setColor(Color.BLACK);
  gd.drawRect(0, 0, width - 1, height - 1);
  gd.setFont(font);
  // 隨機產(chǎn)生40條干擾線,使圖象中的認證碼不易被其它程序探測到。
  int red = 0, green = 0, blue = 0;


  // randomCode用于保存隨機產(chǎn)生的驗證碼,以便用戶登錄后進行驗證。
  StringBuffer randomCode = new StringBuffer();


  // 隨機產(chǎn)生codeCount數(shù)字的驗證碼。
  for (int i = 0; i < codeCount; i++) {
   // 得到隨機產(chǎn)生的驗證碼數(shù)字。
   String code = String.valueOf(codeSequence[random.nextInt(36)]);
   // 產(chǎn)生隨機的顏色分量來構(gòu)造顏色值,這樣輸出的每位數(shù)字的顏色值都將不同。
   red = random.nextInt(255);
   green = random.nextInt(255);
   blue = random.nextInt(255);
   // 用隨機產(chǎn)生的顏色將驗證碼繪制到圖像中。
   gd.setColor(new Color(red, green, blue));
   gd.drawString(code, (i + 1) * xx, codeY);

   // 將產(chǎn)生的四個隨機數(shù)組合在一起。
   randomCode.append(code);
  }
  for (int i = 0; i < 60; i++) {
   red = random.nextInt(255);
   green = random.nextInt(255);
   blue = random.nextInt(255);
   // 用隨機產(chǎn)生的顏色將驗證碼繪制到圖像中。
   gd.setColor(new Color(red, green, blue));
   int x = random.nextInt(width);
   int y = random.nextInt(height);
   int xl = random.nextInt(50);
   int yl = random.nextInt(50);
   gd.drawLine(x, y, x + xl, y + yl);
  }
  Map<String,Object> map =new HashMap<String,Object>();
  //存放驗證碼
  map.put("code", randomCode);
  //存放生成的驗證碼BufferedImage對象
  map.put("codePic", buffImg);
  return map;
 }

 public static void main(String[] args) throws Exception {
  //創(chuàng)建文件輸出流對象
  File file = new File("WebRoot/image/"+System.currentTimeMillis()+".jpg");
  FileOutputStream out = null;
  try {
   if (!file.exists()) {
    // 先得到文件的上級目錄,并創(chuàng)建上級目錄,在創(chuàng)建文件
    file.getParentFile().mkdir();
    file.createNewFile();
   }
   out = new FileOutputStream(file);
  Map<String,Object> map = generateCode.generateCodeAndPic();
  ImageIO.write((RenderedImage) map.get("codePic"), "jpeg", out);
  System.out.println("驗證碼的值為:"+map.get("code"));
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }
 }
}

二、驗證碼驗證類

package verificationCode;


import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;


@WebServlet("/checkCode")
public class checkCode extends HttpServlet {
 private static final long serialVersionUID = 1L;

 protected void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {

 }

 protected void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  String code = request.getParameter("code");
  response.setCharacterEncoding("utf-8");//保證格式正確
  response.setContentType("text/html");
  // 驗證驗證碼
  String sessionCode = request.getSession().getAttribute("code").toString();
  if (code != null && !"".equals(code) && sessionCode != null && !"".equals(sessionCode)) {
   if (code.equalsIgnoreCase(sessionCode)) {
    response.getWriter().println("驗證通過!");
   } else {
    response.getWriter().println("驗證失敗!");
   }
  } else {
   response.getWriter().println("驗證失?。?);
  }
 }

}

三、驗證碼傳輸類

用到doget方法

package verificationCode;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.awt.image.RenderedImage;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import verificationCode.generateCode;
/**
 * Servlet implementation class CodeServlet
 */
@WebServlet("/getCode")
public class CodeServlet extends HttpServlet {
 private static final long serialVersionUID = 1L;

 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  // 調(diào)用工具類生成的驗證碼和驗證碼圖片
  Map<String, Object> codeMap = generateCode.generateCodeAndPic();

  // 將四位數(shù)字的驗證碼保存到Session中。
  HttpSession session = req.getSession();
  session.setAttribute("code", codeMap.get("code").toString());

  // 禁止圖像緩存。
  resp.setHeader("Pragma", "no-cache");
  resp.setHeader("Cache-Control", "no-cache");
  resp.setDateHeader("Expires", 0);

  resp.setContentType("image/jpeg");

  // 將圖像輸出到Servlet輸出流中。
  ServletOutputStream sos;
  try {
   sos = resp.getOutputStream();
   ImageIO.write((RenderedImage) codeMap.get("codePic"), "jpeg", sos);
   sos.close();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }

 }

}

四、jsp驗證demo

<%@ page language="java" contentType="text/html; charset=UTF-8"
 pageEncoding="UTF-8"%>

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>驗證碼頁面</title>
<script type="text/javascript"
 src="${pageContext.request.contextPath}/js/jquery.js"></script>
</head>
<body>
 <form action="${pageContext.request.contextPath}/checkCode" method="post">
  請輸入驗證碼:<input type="text" name="code" style="width: 80px;" /> <div id=random> <img id="imgObj" alt="驗證碼"
   src="${pageContext.request.contextPath}/getCode"> </div><button id="b01" type="button">改變內(nèi)容</button><br/> <input
   type="submit" value="提交" />
 </form>
</body>
<script type="text/javascript">
 $(function() {
  //response.getWriter().println("驗證失??!");
 });

 $("#b01").click( function changeImg() { 


   $("#random").html("<img id='imgObj' alt='驗證碼' src='${pageContext.request.contextPath}/getCode'>")  
   var imgSrc = $("#imgObj"); 
  var src = imgSrc.attr("src");  
  imgSrc.attr("src", chgUrl(src)); 
 });

 // 時間戳
 // 為了使每次生成圖片不一致,即不讓瀏覽器讀緩存,所以需要加上時間戳
 function chgUrl(url) {
  var timestamp = (new Date()).valueOf();
  url = url.substring(0, 20);
  if ((url.indexOf("&") >= 0)) {
   url = url + "×tamp=" + timestamp;
  } else {
   url = url + "?timestamp=" + timestamp;
  }
  return url;
 }

</script>
</html>

總結(jié)

雖然只是一個小小的demo,但是實際上用到了許多知識,比如生成驗證碼的畫圖,傳輸驗證碼doget,驗證驗證碼的dopost和ajax動態(tài)更換驗證碼,麻雀雖小五臟俱全啊。

參考網(wǎng)址: Java實現(xiàn)驗證碼的產(chǎn)生和驗證

更多關(guān)于java驗證碼的精彩文章請點擊專題: java驗證碼大全 進行參考

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java實現(xiàn)銀行存取款

    Java實現(xiàn)銀行存取款

    這篇文章主要為大家詳細介紹了Java實現(xiàn)銀行存取款,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • java程序運行時內(nèi)存分配詳解

    java程序運行時內(nèi)存分配詳解

    這篇文章主要介紹了java程序運行時內(nèi)存分配詳解 ,需要的朋友可以參考下
    2016-07-07
  • java中的instanceof關(guān)鍵字詳細解讀

    java中的instanceof關(guān)鍵字詳細解讀

    這篇文章主要介紹了java中的instanceof關(guān)鍵字詳細解讀,instanceof 是 Java 的保留關(guān)鍵字,它的作用是測試它左邊的對象是否是它右邊的類的實例,返回 boolean 的數(shù)據(jù)類型,需要的朋友可以參考下
    2024-01-01
  • Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式

    Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式

    這篇文章主要介紹了Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java 添加、讀取和刪除 Excel 批注的操作代碼

    Java 添加、讀取和刪除 Excel 批注的操作代碼

    這篇文章主要介紹了Java 添加、讀取和刪除 Excel 批注的操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 詳解springboot中各個版本的redis配置問題

    詳解springboot中各個版本的redis配置問題

    這篇文章主要介紹了詳解springboot中各個版本的redis配置問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Java數(shù)據(jù)結(jié)構(gòu)之圖的兩種搜索算法詳解

    Java數(shù)據(jù)結(jié)構(gòu)之圖的兩種搜索算法詳解

    在很多情況下,我們需要遍歷圖,得到圖的一些性質(zhì)。有關(guān)圖的搜索,最經(jīng)典的算法有深度優(yōu)先搜索和廣度優(yōu)先搜索,接下來我們分別講解這兩種搜索算法,需要的可以參考一下
    2022-11-11
  • 關(guān)于在Java中使用預定義類

    關(guān)于在Java中使用預定義類

    這篇文章主要介紹了關(guān)于在Java中使用預定義類,預定義類就是Java類庫(或第三方庫)中已經(jīng)定義好的類,例如,Math 類和 Date 類,需要的朋友可以參考下
    2023-05-05
  • SpringBoot集成Kaptcha驗證碼的詳細過程

    SpringBoot集成Kaptcha驗證碼的詳細過程

    Kaptcha是一個強大而靈活的Java驗證碼生成庫,通過合理的配置和使用,它可以有效地提高web應用的安全性,防止自動化程序的濫用,這篇文章主要介紹了SpringBoot集成Kaptcha驗證碼,需要的朋友可以參考下
    2024-07-07
  • SpringBoot?整合數(shù)據(jù)源的具體實踐

    SpringBoot?整合數(shù)據(jù)源的具體實踐

    本文主要介紹了SpringBoot?整合數(shù)據(jù)源的具體實踐,利用?Spring?Boot?的自動配置和簡化的注解來簡化數(shù)據(jù)源配置工作,從而更專注于應用程序的業(yè)務邏輯開發(fā),感興趣的可以了解一下
    2023-11-11

最新評論