登錄頁(yè)面經(jīng)常要求輸入隨機數,以避免用網(wǎng)頁(yè)機器人惡意注冊登錄。
雖然有開(kāi)源包來(lái)實(shí)現這些隨機圖片,但是也可以自己寫(xiě)一個(gè)簡(jiǎn)短的代碼來(lái)達到目的。
randomImage.jsp
<%@ page pageEncoding="gb2312"%>
<%@ page contentType="image/jpeg"%>
<%@ page import="java.awt.*"%>
<%@ page import="java.awt.image.*"%>
<%@ page import="java.util.*"%>
<%@ page import="javax.imageio.*"%>
<%
//在內存中創(chuàng )建圖象
int iWidth=50,iHeight=18;
BufferedImage image=new BufferedImage(iWidth,iHeight,BufferedImage.TYPE_INT_RGB);
//獲取圖形上下文
Graphics g=image.getGraphics();
//設定背景色
g.setColor(Color.white);
g.fillRect(0,0,iWidth,iHeight);
//畫(huà)邊框
g.setColor(Color.black);
g.drawRect(0,0,iWidth-1,iHeight-1);
//取隨機產(chǎn)生的認證碼(4位數字)
String rand=request.getParameter("Rand");
rand=rand.substring(0,rand.indexOf("."));
switch(rand.length())
{
case 1:rand="000"+rand;break;
case 2:rand="00"+rand;break;
case 3:rand="0"+rand;break;
default:rand=rand.substring(0,4);break;
}
//將認證碼存入SESSION
session.setAttribute("Rand",rand);
//將認證碼顯示到圖象中
g.setColor(Color.black);
g.setFont(new Font("Times New Roman",Font.PLAIN,18));
g.drawString(rand,10,15);
//隨機產(chǎn)生88個(gè)干擾點(diǎn),使圖象中的認證碼不易被其它程序探測到
Random random=new Random();
for(int iIndex=0;iIndex<88;iIndex++)
{
int x=random.nextInt(iWidth);
int y=random.nextInt(iHeight);
g.drawLine(x,y,x,y);
}
//圖象生效
g.dispose();
out.clear();
out = pageContext.pushBody();
//輸出圖象到頁(yè)面
ImageIO.write(image,"JPEG",response.getOutputStream());
%>
然后在登錄頁(yè)面中需要顯示圖片的位置引用上面的randomImage.jsp:
<script>document.write("<img border=0 src='<%=request.getContextPath()%>/randomImage.jsp?Rand="+Math.random()*10000+"' align='absmiddle'>");</script>
本文來(lái)自CSDN博客,轉載請標明出處:http://blog.csdn.net/kingspider/archive/2008/11/14/3297310.aspx
聯(lián)系客服