java 圖片驗證碼的完成代碼。本站提示廣大學習愛好者:(java 圖片驗證碼的完成代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是java 圖片驗證碼的完成代碼正文
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
* 生成驗證碼圖片
*/
public class makeCertPic {
//驗證碼圖片中可以湧現的字符集,可依據須要修正
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'};
/**
* 功效:生成黑色驗證碼圖片
* 參數width為生成圖片的寬度,參數height為生成圖片的高度,參數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();
// 設定配景色
g.setColor(new Color(0xDCDCDC));
g.fillRect(0, 0, width, height);
//畫邊框
g.setColor(Color.black);
g.drawRect(0,0,width-1,height-1);
// 取隨機發生的認證碼
String strEnsure = "";
// 4代表4位驗證碼,假如要生成更多位的認證碼,則加年夜數值
for(int i=0; i<4; ++i) {
strEnsure+=mapTable[(int)(mapTable.length*Math.random())];
}
// 將認證碼顯示到圖象中,假如要生成更多位的認證碼,增長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);
// 隨機發生10個攪擾點
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()辦法中,起首創立了一個內存圖象的實例對象,再獲得此內存圖象的圖形高低文對象,接著再用這個高低文對象畫配景、邊框。接上去,隨機生成4個在mapTable[]數組中的字符,構成字符串作為驗證字符串,並輸入在內存中,為了形成必定的攪擾,隨機畫了10個攪擾點,假如要加年夜攪擾後果,可再多畫一些點。
makeCertPic.jsp頁面用於挪用生成驗證碼圖片的JavaBean,並在客戶端顯示,源代碼以下:
makeCertPic.jsp
<%@page contentType="image/jpeg" %>
<jsp:useBean id="image" scope="page" class="pic.makeCertPic" />
<%
String str=image.getCertPic(0,0,response.getOutputStream());
// 將認證碼存入SESSION
session.setAttribute("certCode", str);
out.clear();
out = pageContext.pushBody();
%>
這裡把生成的驗證碼作為session變量寫入,是以在吸收登錄頁面輸出的數據頁面中,可用用戶輸出的驗證碼和這個session變量作比擬,假如雷同則表現驗證經由過程。
LoginPic.jsp
<%@ 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>體系登錄</td></tr>
<form. action="loginCheck.jsp" method="post" focus="username">
<tr><td>用戶名:<input type="text" name="username"/></td></tr>
<tr><td>密 碼:<input type="password"name="password"/></td></tr>
<tr><td>驗證碼<img src="makeCertPic.jsp" id="code" onclick="reloadcode()" alt="看不清晰,換一張"> </td></tr>
<tralign="left"><td>
<input type="submit" value="肯定"/></td></tr>
</form>
</table>
</body>
</html>
驗證碼的輸出能否准確可用以下語句驗證:
String certCode=request.getParameter("certCode");
if(certCode.equals((String)session.getAttribute("certCode")))
out.print("驗證碼輸出准確");
else
out.print("驗證碼輸出毛病");