程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> JSP中圖片驗證的實現

JSP中圖片驗證的實現

編輯:關於JSP

[前言]:圖片驗證在有關注冊和發表留言經常用到.我在此用jsp寫了個.供大家參考. 其中 com.sun.image 不是java的標准包.需要另外下載.相關地址為:

  http://java.sun.com/products/java-media/jai/

  1. random.jsp (產生四位的隨機字符,由0-9,a-z,A-Z構成.並把最終字符串放到session中保存以讓後續頁面驗證真偽)

  代碼如下:

<%@ page autoFlush="false" import="java.util.*,java.awt.*,java.awt.image.*,
com.sun.image.codec.jpeg.*,java.util.*"%>

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

<%

String chose=
"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
char display[]={0, ,0, ,0, ,0},ran[]={0,0,0,0},temp;
Random rand=new Random();
for(int i=0;i<4;i++)

{
temp=chose.charAt(rand.nextInt(chose.length()));
display[i*2]=temp;
ran[i]=temp;

}



String random=String.valueOf(display);
session.setAttribute("random",String.valueOf(ran));

%>

<%
out.clear();

response.setContentType("image/jpeg");

response.addHeader("pragma","NO-cache");

response.addHeader("Cache-Control","no-cache");

response.addDateHeader("Expries",0);

int width=47, height=15;

BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

Graphics g = image.getGraphics();

//以下填充背景顏色

g.setColor(Color.GREEN);

g.fillRect(0, 0, width, height);

//設置字體顏色

g.setColor(Color.RED);

g.drawString(random,3,10);

g.dispose();

ServletOutputStream outStream = response.getOutputStream();

JPEGImageEncoder encoder =JPEGCodec.createJPEGEncoder(outStream);

encoder.encode(image);

outStream.close();

%>


本新聞共2頁,當前在第1頁  1  2  


2. img.jsp (顯示驗證圖片.由於本程序簡單讓驗證程序也一並放在了一起)

  代碼如下:

<%@ page contentType="text/html; charset=gb2312" language="java"%>

<%

String num=request.getParameter("num");

String random=(String)session.getAttribute("random");
if(num!=null&&random!=null)

{

if(!num.equals(random))

{

out.println("<script>alert(驗證碼錯誤!請重試。)</script>");
out.println("<script>history.go(-1)</script>");
//response.sendRedirect("img.jsp");

}

else

{

out.println("<center>驗證成功!</center>");

}

}

%>

<html>

<head>

<title>圖片驗證</title>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

</head>
<body>

<form action="img.jsp" method="post">

<table>

<tr>

<td>

<input type="text" name="num" size=10>

</td>

<td>

<img src="random.jsp">

</td>

</tr>

</table>

<input type="submit" value="OK">

</form>

</body>

</html>


  說明:有興趣的網友可以在此基礎上增加圖片的內容.比如讓背景加上紋理.讓字符位置歪斜以加大掃描程序的難度.大家有什麼看法和建議,都可以回復中提出來....

本新聞共2頁,當前在第2頁  1  2  


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved