驗證碼應用在各種場合中,十分廣泛,在多種多樣的系統或軟體中的新使用者帳戶註冊、使用者登入、網 站統一登陸或者使用者在網站發布資訊模組發布文章或內容都添加的隨機碼功能,對使用者操作過程進行一種 驗證,使用驗證碼的目的就是為了避免網路中的自動註冊程式或者自動發布程式的濫用。 驗證碼的原理 其實就是隨機播放一些字元碼以將字元碼以圖片的形式展現在軟體驗證介面或驗證頁面上,當使用者在進行 提交操作的同時需要將圖片上的驗證碼輸入並同時提交,如果提交的字元驗證碼與伺服器session儲存的 字元碼相同,則認為提交資訊有效,否則拒絕提交。在使用驗證碼過程中,為了避免自動剖析器解析圖 片並獲得驗證資訊,通常需要在圖片上隨機產生一些幹擾線或者將複雜的字元對圖片進行扭曲模糊,從而 增加了自動識別程式分析驗證圖片的難度。
JSP驗證碼源碼大全將分別用幾個篇幅的內容來介紹在JSP中幾種驗證碼的實現源碼以及使用。
一、JSP中產生數字驗證碼源碼
數字驗證碼是一種最常用的驗證字元碼形式,以下為數字實現的JSP源碼:
Num.jsp
<%@ page contentType="image/jpeg" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
<%!
Color getRandColor(int cc,int bb)
{
Random random = new Random();
if(fc>255) cc=255;
if(bc>255) bb=255;
int r=cc+random.nextInt(bb-cc);
int g=cc+random.nextInt(bb-cc);
int b=cc+random.nextInt(bb-cc);
returnnew Color(r,g,b);
} //擷取隨機顏色
%>
<%
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
int width=80; //定義驗證碼圖片的長度
int height=30; //定義驗證碼圖片的寬度
BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
Graphics g = image.getGraphics();
Random random = new Random();
g.setColor(getRandColor(200,250));
g.fillRect(0, 0, width, height);
g.setFont(new Font("Times New Roman",Font.PLAIN,18));
//定義字型形式
g.setColor(getRandColor(160,200));
for (int i=0;i<155;i++)
{
int i_x = random.nextInt(width);
int i_y = random.nextInt(height);
int i_xl = random.nextInt(12);
int i_yl = random.nextInt(12);
g.drawLine(i_x,i_y,i_x+i_xl,i_y+i_yl);
}
//用線條畫背景
String s_Rand="";
for (int i=0;i<4;i++)
{
String rand=String.valueOf(random.nextInt(10));
s_Rand+=rand;
g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt (110)));
g.drawString(rand,13*i+6,16);
}
//產生4位隨機碼
session.setAttribute("rand",s_Rand);
//將驗證碼存入Session中
g.dispose();
ImageIO.write(image, "JPEG", response.getOutputStream());
//輸出驗證圖片
out.clear();
out = pageContext.pushBody();
%>
接下來文章將介紹JSP中的中文驗證碼、其他JAVA驗證碼的實現以及對JSP中對驗證碼的調用和使用的 有關內容,下一篇文章將介紹有關JSP中文驗證碼的源碼實現。