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

java 圖片驗(yàn)證碼的實(shí)現(xiàn)代碼

 更新時間:2013年05月21日 09:47:43   作者:  
java 圖片驗(yàn)證碼的實(shí)現(xiàn)代碼,需要的朋友可以參考一下

復(fù)制代碼 代碼如下:

makeCertPic.java
  package pic;
  import java.awt.Color;
  import java.awt.Font;
  import java.awt.Graphics;
  import java.awt.image.BufferedImage;
  import java.io.IOException;
  import java.io.OutputStream;
  import java.util.Random;
  import javax.imageio.ImageIO;
  /**
   * @author dzy
   * 生成驗(yàn)證碼圖片
   */
  public class makeCertPic {
    //驗(yàn)證碼圖片中可以出現(xiàn)的字符集,可根據(jù)需要修改
    private char mapTable[]={
       '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'};
    /**
    * 功能:生成彩色驗(yàn)證碼圖片
    * 參數(shù)width為生成圖片的寬度,參數(shù)height為生成圖片的高度,參數(shù)os為頁面的輸出流
    */
   public String getCertPic(int width, int height, OutputStream os) {
   if(width<=0)width=60;
   if(height<=0)height=20;
   BufferedImage image = new BufferedImage(width, height,
      BufferedImage.TYPE_INT_RGB);
   // 獲取圖形上下文
   Graphics g = image.getGraphics();
   // 設(shè)定背景色
   g.setColor(new Color(0xDCDCDC));
   g.fillRect(0, 0, width, height);
   //畫邊框
   g.setColor(Color.black);
   g.drawRect(0,0,width-1,height-1);
   // 取隨機(jī)產(chǎn)生的認(rèn)證碼
   String strEnsure = "";
   // 4代表4位驗(yàn)證碼,如果要生成更多位的認(rèn)證碼,則加大數(shù)值
   for(int i=0; i<4; ++i) {
strEnsure+=mapTable[(int)(mapTable.length*Math.random())];
   } 
   //   將認(rèn)證碼顯示到圖像中,如果要生成更多位的認(rèn)證碼,增加drawString語句
   g.setColor(Color.black);
   g.setFont(new Font("Atlantic Inline",Font.PLAIN,18));
   String str = strEnsure.substring(0,1);
   g.drawString(str,8,17);
   str = strEnsure.substring(1,2);
   g.drawString(str,20,15);
   str = strEnsure.substring(2,3);
   g.drawString(str,35,18);  
   str = strEnsure.substring(3,4);
   g.drawString(str,45,15);
   // 隨機(jī)產(chǎn)生10個干擾點(diǎn)
   Random rand = new Random();
   for (int i=0;i<10;i++) {
    int x = rand.nextInt(width);
    int y = rand.nextInt(height);
    g.drawOval(x,y,1,1);
   }
   // 釋放圖形上下文
   g.dispose();  
   try {
    // 輸出圖像到頁面
    ImageIO.write(image, "JPEG", os);
   } catch (IOException e) {
    return "";
   } 
   return strEnsure;
   }
  }

  在getCertPic()方法中,首先創(chuàng)建了一個內(nèi)存圖像的實(shí)例對象,再得到此內(nèi)存圖像的圖形上下文對象,接著再用這個上下文對象畫背景、邊框。接下來,隨機(jī)生成4個在mapTable[]數(shù)組中的字符,組成字符串作為驗(yàn)證字符串,并輸出在內(nèi)存中,為了造成一定的干擾,隨機(jī)畫了10個干擾點(diǎn),如果要加大干擾效果,可再多畫一些點(diǎn)。
makeCertPic.jsp頁面用于調(diào)用生成驗(yàn)證碼圖片的JavaBean,并在客戶端顯示,源代碼如下:
  makeCertPic.jsp

復(fù)制代碼 代碼如下:

  <%@page contentType="image/jpeg" %>
  <jsp:useBean id="image" scope="page" class="pic.makeCertPic" />
  <%
  String str=image.getCertPic(0,0,response.getOutputStream());
     // 將認(rèn)證碼存入SESSION
  session.setAttribute("certCode", str);

  out.clear();
   out = pageContext.pushBody();
  %>

  這里把生成的驗(yàn)證碼作為session變量寫入,因此在接收登錄頁面輸入的數(shù)據(jù)頁面中,可用用戶輸入的驗(yàn)證碼和這個session變量作比較,如果相同則表示驗(yàn)證通過。
  LoginPic.jsp

復(fù)制代碼 代碼如下:

  <%@ page contentType="text/html;charset=GB2312" %>

<script type="text/javascript">
  function reloadcode(){
                var verify=document.getElementById('code');
                verify.setAttribute('src','makeCertPic.jsp?it='+Math.random());
        }
</script>
  <html>
   <head><title>登錄頁面</title></head>
   <body>
     <table align="center" border="0">
   <tralign="center"><td><fontcolor="red"><html:errors/></font></td></tr>
   <tr align="center"><td>系統(tǒng)登錄</td></tr>
   <form. action="loginCheck.jsp" method="post" focus="username">
   <tr><td>用戶名:<input type="text" name="username"/></td></tr>
     <tr><td>密&nbsp;&nbsp;碼:<input type="password"name="password"/></td></tr>
   <tr><td>驗(yàn)證碼<img src="makeCertPic.jsp" id="code" onclick="reloadcode()" style="cursor: pointer;" alt="看不清楚,換一張"> </td></tr>
<tralign="left"><td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
   <input type="submit" value="確定"/></td></tr>
   </form>
   </table>
   </body>
  </html>

  驗(yàn)證碼的輸入是否正確可用如下語句驗(yàn)證:

復(fù)制代碼 代碼如下:

  String certCode=request.getParameter("certCode");
  if(certCode.equals((String)session.getAttribute("certCode")))
   out.print("驗(yàn)證碼輸入正確");
  else
   out.print("驗(yàn)證碼輸入錯誤");

相關(guān)文章

  • Spring AOP定義Before增加實(shí)戰(zhàn)案例詳解

    Spring AOP定義Before增加實(shí)戰(zhàn)案例詳解

    這篇文章主要介紹了Spring AOP定義Before增加,結(jié)合實(shí)例形式詳細(xì)分析了Spring面向切面AOP定義Before增加相關(guān)定義與使用技巧,需要的朋友可以參考下
    2020-01-01
  • JavaMail郵件簡介及API概述第一篇

    JavaMail郵件簡介及API概述第一篇

    這篇文章主要為大家詳細(xì)介紹了JavaMail郵件簡介及API概述第一篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟

    SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟

    這篇文章主要介紹了SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟,文中通過代碼示例和圖文講解的非常詳細(xì),對大家實(shí)現(xiàn)OneDrive文件上傳有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • spring security實(shí)現(xiàn)下次自動登錄功能過程解析

    spring security實(shí)現(xiàn)下次自動登錄功能過程解析

    這篇文章主要介紹了spring security實(shí)現(xiàn)記住我下次自動登錄功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Java多線程之定時器Timer的實(shí)現(xiàn)

    Java多線程之定時器Timer的實(shí)現(xiàn)

    定時/計劃功能在Java應(yīng)用的各個領(lǐng)域都使用得非常多,比方說Web層面。本文主要為大家介紹了Java多線程中定時器Timer的實(shí)現(xiàn),感興趣的小伙伴可以了解一下
    2022-10-10
  • Java Http多次請求復(fù)用同一連接示例詳解

    Java Http多次請求復(fù)用同一連接示例詳解

    這篇文章主要為大家介紹了Java Http多次請求復(fù)用同一連接示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Springboot 跨域配置無效及接口訪問報錯的解決方法

    Springboot 跨域配置無效及接口訪問報錯的解決方法

    這篇文章主要介紹了Springboot 跨域配置無效及接口訪問報錯的解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • 圖解JVM垃圾內(nèi)存回收算法

    圖解JVM垃圾內(nèi)存回收算法

    這篇文章主要介紹了圖解JVM垃圾內(nèi)存回收算法,由于年輕代堆空間的垃圾回收會很頻繁,因此其垃圾回收算法會更加重視回收效率,下面小編就和大家來一起學(xué)習(xí)一下吧
    2019-06-06
  • 解決Spring或SpringBoot開啟事務(wù)以后無法返回自增主鍵的問題

    解決Spring或SpringBoot開啟事務(wù)以后無法返回自增主鍵的問題

    這篇文章主要介紹了解決Spring或SpringBoot開啟事務(wù)以后無法返回自增主鍵的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • maven打包zip包含bin下啟動腳本的完整代碼

    maven打包zip包含bin下啟動腳本的完整代碼

    這篇文章主要介紹了maven打包zip包含bin下啟動腳本,本文給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10

最新評論