動態(tài)生成驗證碼_JSP教程
推薦:Jsp驗證碼(檢驗碼)實例代碼利用Apache的一個 開源項目Image Tag Library(http://jakarta.apache.org/taglibs/sandbox/doc/image-doc/intro.html) 下載必要文件 1)下載Jakarta-Taglibs: http://people.apache.org/builds/jakarta-taglibs-sandbox/nightly/ 解壓后取出taglibs-image.jar
下面一個實例講述如何動態(tài)生成驗證碼及驗證碼是否匹配。
顯示驗證碼的html頁面login.html代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>login.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
</head>
<body>
<center>
<form action="login" method="post">
驗證碼:<input type="text" name="random"><img src="imgcode">
<br>
<br>
<input type="submit" value="提交">
</form>
</center>
</body>
</html>
動態(tài)生成驗證碼的servlet類RandomCodeServlet.java代碼如下:
package iss;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.util.Random;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import javax.imageio.*;
public class RandomCodeServlet extends HttpServlet ...{
/** *//**
* Constructor of the object.
*/
public RandomCodeServlet() ...{
super();
}
//驗證碼圖片的寬度
private int width=60;
//驗證碼圖片的高度
private int height=20;
protected void service(HttpServletRequest request,HttpServletResponse response)
throws ServletException,java.io.IOException...{
BufferedImage buffImg=new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
Graphics2D g=buffImg.createGraphics();
//創(chuàng)建一個隨機數(shù)生成器
Random random=new Random();
g.setColor(Color.WHITE);
g.fillRect(0, 0, width, height);
//創(chuàng)建字體,字體的大小應該根據(jù)圖片的高度來定
Font font=new Font("Times New Roman",Font.PLAIN,18);
//設置字體
g.setFont(font);
//畫邊框
g.setColor(Color.BLACK);
g.drawRect(0, 0, width-1, height-1);
//隨機產(chǎn)生160條干擾線
g.setColor(Color.GRAY);
for(int i=0;i<160;i++)...{
int x=random.nextInt(width);
int y=random.nextInt(height);
int x1=random.nextInt(12);
int y1=random.nextInt(12);
g.drawLine(x, y, x+x1, y+y1);
}
//randomCode用于保存隨機產(chǎn)生的驗證碼
StringBuffer randomCode=new StringBuffer();
int red=0,green=0,blue=0;
//隨機產(chǎn)生4位數(shù)字的驗證碼
for(int i=0;i<4;i++)...{
//得到隨機產(chǎn)生的驗證碼數(shù)字
String strRand=String.valueOf(random.nextInt(10));
//產(chǎn)生隨機的顏色分量來構造顏色值
red=random.nextInt(110);
green=random.nextInt(50);
blue=random.nextInt(50);
//用隨機產(chǎn)生的顏色將驗證碼繪制到圖像中
g.setColor(new Color(red,green,blue));
g.drawString(strRand, 13*i+6, 16);
randomCode.append(strRand);
}
//將四位數(shù)字的驗證碼保存到session中
HttpSession session=request.getSession();
session.setAttribute("randomCode", randomCode.toString());
//禁止圖像緩存
response.setHeader("Pragma", "no-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
response.setContentType("image/jpeg");
//將圖像輸出到servlet輸出流中
ServletOutputStream sos=response.getOutputStream();
ImageIO.write(buffImg, "jpeg", sos);
sos.close();
}
}
判斷驗證碼是否匹配的LoginServlet.java代碼如下:
package iss;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class LoginServlet extends HttpServlet ...{
/** *//**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to post.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
HttpSession session=request.getSession();
String randomCode=(String)session.getAttribute("randomCode");
if(null==randomCode)...{
response.sendRedirect("login.html");
return;
}
String reqRandom=request.getParameter("random");
response.setCharacterEncoding("gbk");
response.setContentType("text/html;charset=gb2312");
PrintWriter out = response.getWriter();
if(randomCode.equals(reqRandom))...{
out.println("驗證碼匹配!");
}else...{
out.println("驗證碼不匹配!");
}
out.close();
}
}
web.xml如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<description>This is the description of my J2EE component</description>
<display-name>This is the display name of my J2EE component</display-name>
<servlet-name>RandomCodeServlet</servlet-name>
<servlet-class>iss.RandomCodeServlet</servlet-class>
</servlet>
<servlet>
<description>This is the description of my J2EE component</description>
<display-name>This is the display name of my J2EE component</display-name>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>iss.LoginServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RandomCodeServlet</servlet-name>
<url-pattern>/imgcode</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>
</web-app>
分享:網(wǎng)頁無閃自動局部刷新實例我們在網(wǎng)頁制作的過程中經(jīng)常會遇到及時刷新數(shù)據(jù)的問題,如果使用 meta http-equiv=refresh content=300 的方法,會造成整個屏幕不斷閃爍刷新的效果,這會降低用戶的操作滿意度。所以我們需要一種可以實現(xiàn)無閃自動刷新數(shù)據(jù)的方法來解決以上問題。 實例解決
- jsp response.sendRedirect不跳轉(zhuǎn)的原因分析及解決
- JSP指令元素(page指令/include指令/taglib指令)復習整理
- JSP腳本元素和注釋復習總結示例
- JSP FusionCharts Free顯示圖表 具體實現(xiàn)
- 網(wǎng)頁模板:關于jsp頁面使用jstl的異常分析
- JSP頁面中文傳遞參數(shù)使用escape編碼
- 基于jsp:included的使用與jsp:param亂碼的解決方法
- Java Web項目中連接Access數(shù)據(jù)庫的配置方法
- JDBC連接Access數(shù)據(jù)庫的幾種方式介紹
- 網(wǎng)站圖片路徑的問題:絕對路徑/虛擬路徑
- (jsp/html)網(wǎng)頁上嵌入播放器(常用播放器代碼整理)
- jsp下顯示中文文件名及絕對路徑下的圖片解決方法
- 相關鏈接:
- 教程說明:
JSP教程-動態(tài)生成驗證碼
。