Java圖形驗證碼_第1頁
Java圖形驗證碼_第2頁
Java圖形驗證碼_第3頁
Java圖形驗證碼_第4頁
Java圖形驗證碼_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、思路:圖片驗證碼的實現(xiàn)主要的技術(shù)點是如何生成一個圖片。生成圖片可以使用java.awt包下的類來實現(xiàn)。我們先寫一個簡單的生成圖片的程序HelloImage.java。以下是代碼部分。 package com.vogoal.test;import java.awt.Color;import java.awt.Graphics;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import javax.imageio.ImageIO;/* author SinNeR * create

2、 a image*/public class HelloImage public static void main(String args)BufferedImage image = new BufferedImage(80, 25,BufferedImage.TYPE_INT_RGB);Graphics g = image.getGraphics();g.setColor(new Color(255,255,255);g.fillRect(0, 0, 80, 25);g.setColor(new Color(0,0,0);g.drawString("HelloImage"

3、,6,16); g.dispose();tryImageIO.write(image, "jpeg", new File("C:helloImage.jpeg");catch(IOException e)e.printStackTrace(); 編譯后,在DOS下調(diào)用這個程序,正常情況下,會在C盤根目錄下生成一張名字helloImage.jpeg為的圖片。圖片上有文字HelloImage。 簡單介紹下生成圖片的流程: 建立BufferedImage對象。指定圖片的長度寬度和色彩。BufferedImage image = new BufferedImag

4、e(80,25,BufferedImage.TYPE_INT_RGB); 取得Graphics對象,用來繪制圖片。Graphics g = image.getGraphics(); 繪制圖片背景和文字。 釋放Graphics對象所占用的資源。g.dispose(); 通過ImageIO對象的write靜態(tài)方法將圖片輸出。ImageIO.write(image, "jpeg", new File("C:helloImage.jpeg"); 知道了圖片的生成方法,剩下的問題就是如何將隨機數(shù)生成到頁面上了。要顯示圖片,我們只要將生成的圖片流返回給respons

5、e對象,這樣用戶請求的時候就可以得到圖片。而一個jsp頁面的page參數(shù)的contentType屬性可以指定返回的response對象的形式,我們平時的jsp頁面中設(shè)定的contentType是text/html,所以會被以HTML文件的形式讀取分析。如果設(shè)定為image/jpeg,就會被以圖片的形式讀取分析。確定了這點后就可以著手實現(xiàn)。 修改生成圖片的類,添加生成隨機字符串的方法,并取得用戶傳過來的response對象將圖片流輸出到response對象中。同時為了更友好和可訂制,添加了一個構(gòu)造函數(shù),可以修改圖片驗證碼的長度,以及驗證碼的碼字范圍。并且可以設(shè)定驗證碼的背景色。(用戶使用時可以設(shè)

6、定驗證圖片的背景色與頁面的背景色相同) 寫一個jsp文件,用來調(diào)用生成驗證碼圖片的類。并得到生成的驗證碼,存入session。 以下是生成驗證碼圖片的類RandImgCreater。(操作系統(tǒng)的原因,沒有寫注釋,避免亂碼) package com.vogoal.util.img;import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.image.BufferedImage;import java.io.IOException;import java.util.Random;impor

7、t javax.imageio.ImageIO;import javax.servlet.http.HttpServletResponse;/* author SinNeR* * image check creater*/public class RandImgCreater private static final String CODE_LIST = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890"private HttpServletResponse response = null;pri

8、vate static final int HEIGHT = 20;private static final int FONT_NUM = 4;private int width = 0;private int iNum = 0;private String codeList = ""private boolean drawBgFlag = false;private int rBg = 0;private int gBg = 0;private int bBg = 0;public RandImgCreater(HttpServletResponse response)

9、this.response = response;this.width = 13 * FONT_NUM + 12;this.iNum = FONT_NUM;this.codeList = CODE_LIST;public RandImgCreater(HttpServletResponse response,int iNum,String codeList) this.response = response;this.width = 13 * iNum + 12;this.iNum = iNum;this.codeList = codeList; public String createRan

10、dImage()BufferedImage image = new BufferedImage(width, HEIGHT,BufferedImage.TYPE_INT_RGB);Graphics g = image.getGraphics();Random random = new Random();if ( drawBgFlag )g.setColor(new Color(rBg,gBg,bBg);g.fillRect(0, 0, width, HEIGHT);elseg.setColor(getRandColor(200, 250); g.fillRect(0, 0, width, HE

11、IGHT);for (int i = 0; i < 155; i+) g.setColor(getRandColor(140, 200);int x = random.nextInt(width);int y = random.nextInt(HEIGHT);int xl = random.nextInt(12);int yl = random.nextInt(12);g.drawLine(x, y, x + xl, y + yl); g.setFont(new Font("Times New Roman", Font.PLAIN, 18);String sRand=

12、""for (int i=0;i<iNum;i+)int rand=random.nextInt(codeList.length();String strRand=codeList.substring(rand,rand+1);sRand+=strRand;g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110);g.drawString(strRand,13*i+6,16); g.dispose();tryImageIO.write(image,

13、 "JPEG", response.getOutputStream();catch(IOException e)return sRand;public void setBgColor(int r,int g,int b)drawBgFlag = true;this.rBg = r;this.gBg = g;this.bBg = b;private Color getRandColor(int fc, int bc) Random random = new Random();if (fc > 255)fc = 255;if (bc > 255)bc = 255;i

14、nt r = fc + random.nextInt(bc - fc);int g = fc + random.nextInt(bc - fc);int b = fc + random.nextInt(bc - fc);return new Color(r, g, b);以下是調(diào)用生成驗證碼圖片的類的jsp文件:<% page contentType="image/jpeg" import="com.vogoal.util.img.*" %><%response.setHeader("Pragma","No

15、-cache");response.setHeader("Cache-Control","no-cache");response.setDateHeader("Expires", 0);RandImgCreater rc = new RandImgCreater(response);/RandImgCreater rc = new RandImgCreater(response,8,"abcdef");/rc.setBgColor(100,100,100);String rand = rc.createR

16、andImage();session.setAttribute("rand",rand);%> 將java程序編譯后得到的class,放到Tomcat自己的web應(yīng)用的class的目錄下,并寫一個測試程序。 請求頁面: <form name="frm" method="post" action="chkImg.jsp">Hello Image Test<br/>checkCode:<img src="img.jsp"><br/>please

17、input the checkCode:<input type="text" name="code" value=""><br/><input type="submit" name="btn1" value="check"></form> 驗證頁面: <%String inputCode = request.getParameter("code");String code = (String)sessi

18、on.getAttribute("rand");if ( inputCode.equals(code) )%>check SUCCESS!<%else%>wrong code!<%> 將所有的jsp文件放到自己的web應(yīng)用的目錄下。 開始測試: 啟動Tomcat,訪問請求頁面。 填入圖片上顯示的驗證碼,點擊check按鈕,可以看到如下畫面。測試成功。 至此,jsp的圖片驗證碼基本實現(xiàn)。實際中,我們可以用java的圖片類實現(xiàn)更多的功能。如果有必要,會繼續(xù)討論實現(xiàn)方法。 使用幫助: 附件中提供了圖片生成類和jsp文件,測試jsp文件的下載。使用過程中,可以修改img.jsp文件,從而符合自己要實現(xiàn)的功能要求。 1構(gòu)造函數(shù)RandImgCreater提供了2個構(gòu)造函數(shù)。默認(rèn)的構(gòu)造函數(shù)需要設(shè)定response對象。public RandImgCreater(HttpServletResponse response)使用這個構(gòu)造函數(shù)的時候,生成4位驗證碼圖片,驗證碼為大小寫英文字母和數(shù)字中的隨機組合。public RandImgCreater(HttpServletResponse response,int iNum,String codeList)使用這個構(gòu)造函數(shù)的時候,iNum為指定的顯

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論