關於jsp驗證碼生成,顯示,驗證和刷新: 1:四位數據的驗證圖片生成,用servlet實現
2:在web.xmlli配置servlet
3:頁面上顯示servlet生成的圖片
4:關於驗證碼輸入數據的驗證
5:驗證碼的刷新
——————————————————————–
1:四位數據的驗證圖片生成,用servlet實現,servlet代碼如下:
import java.io.*;
import javax.servlet.http.*;
import javax.servlet.*;
import java.util.*;
import java.awt.*;
import java.awt.image.*;
import javax.imageio.*;
public class vImage extends HttpServlet {
public void init(ServletConfig conf) throws ServletException {
super.init(conf);
}
public void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
res.setContentType(”image/jpeg”);
res.setHeader(”Pragma”, “No-cache”);
res.setHeader(”Cache-Control”, “no-cache”);
res.setDateHeader(”Expires”, 0);
HttpSession session = req.getSession();
// 在內存中創建圖象
int width = 60, height = 20;
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(new Color());
//g.drawRect(0,0,width-1,height-1);
// 隨機產生155條干擾線,使圖象中的認證碼不易被其它程序探測到
g.setColor(getRandColor(160, 200));
for (int i = 0; i 255) fc = 255;
if (bc > 255) bc = 255;
int r = fc + random.nextInt(bc - fc);
int g = fc + random.nextInt(bc - fc);
int b = fc + random.nextInt(bc - fc);
return new Color(r, g, b);
}
}
2: 在web.xmlli配置servlet:
vImage
/vimage
注:注意元素在web.xml文件裡的位置
3:頁面上顯示servlet生成的圖片:
注:在需要顯示驗證碼的地方加上這句,name在刷新驗證碼的時候會用到。
4: 關於驗證碼輸入數據的驗證:
驗證碼生成時存入了session,就是servlet裡的這句session.setAttribute(”post_validate_code”, sRand);具體驗證就不多說了。
5: 驗證碼的刷新
刷新驗證碼
function reloadImage(url)
{
document.form名字.pic.src = url;
}