JSP+Servlet实现验证码生成

主要利用JSP+Servlet实现验证码生成

利用JQuery的ajax技术实现异步更换图片地址

BufferedImage实现验证码图片的生成

Servlet代码:

package Register;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
 * Servlet implementation class GetCode
 */
public class GetCode extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public GetCode() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        BufferedImage img = new BufferedImage(100,30,BufferedImage.TYPE_INT_ARGB_PRE);
        Graphics g =img.getGraphics();
        g.setColor(Color.gray);
        g.fillRect(0, 0, 80, 30);        //画验证码背景
        g.setColor(Color.white);
        g.setFont(new Font("宋体",Font.BOLD,30));
        Random rand = new Random();
        String code = "";
        for(int i=0;i<4;i++){                       //随机生成4位数字验证码
            code += rand.nextInt(10);
        }
        g.drawString(code, 5, 25);
        ImageIO.write(img, "png", new File("d:/"+code+".png"));            //生成验证码图片
        response.getWriter().println(code);                 //验证码返回前台
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request,response);
    }

}

前台JSP页面:

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/jquery-1.10.2.js"></script>
<script type="text/javascript">
$(document).ready(function(){
    var code;
    $.ajax({                                 //接收验证码
        url:"GetCode",
        type:"POST",
        success:function(data, textStatus){
                code =$.trim(data);
                $("img").attr({ src:"d:/"+code+".png"});            //改变验证码地址
        },
        error:function(XMLHttpRequest, textStatus, errorThrown){

    }
    });

    $("#img").click(function(){                //img标签绑定点击事件,点击更换图片
        $.ajax({
            url:"GetCode",
            type:"POST",
            success:function(data, textStatus){
                    code =$.trim(data);
                    $("img").attr({ src:"d:/"+code+".png"});
            },
            error:function(XMLHttpRequest, textStatus, errorThrown){

        }
        });
    });

    $("#code").blur(function(){                  //判断输入的验证码和生成的是否一致
        if($("#code").val()!=code){
            $("#code").css("background-color","#F00");
        }
        else{
            $("#code").css("background-color","#0f0");
        }

    });

});
</script>
</head>
<body>
    <form action="#">
        帐&nbsp;&nbsp;&nbsp;&nbsp;号<input type="text" name="username" id="username" /><br><br>
        密&nbsp;&nbsp;&nbsp;&nbsp;码<input type="password" name="password" id="password" /><br><br>
        验证码<input type="text" name="code" id="code" /><img id="img"  src="#"><br><br>
        <input type="submit" value="注册">
    </form>
</body>
</html>
时间: 2024-08-02 17:22:39

JSP+Servlet实现验证码生成的相关文章

JSP+servlet生成验证码并验证

生成验证码的基本过程是: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ page import="java.awt.*,java.awt.image.BufferedImage,javax.imageio.ImageIO" %> <% response.setHeader("Cache-C

GOOGLE kaptcha 验证码生成插件 servlet/jsp项目中使用步骤

步骤一: 在项目中添加kaptchar的jar包,下载地址:http://code.google.com/p/kaptcha/(建议使用迅雷下载) 步骤二: 配置web.xml,详细配置如下(这里不是所有的配置,这里的参数还有很多可以酌情精简): <!-- 配置验证码插件servlet类 --> <servlet> <servlet-name>kaptcha</servlet-name> <servlet-class> com.google.co

java web验证码生成总结(包括servlet、jsp和struts2实现)(转)

一.使用纯Servlet实现验证码 (1)在web.xml配置: [java] view plaincopy <servlet> <servlet-name>image</servlet-name> <servlet-class>org.test.web.AuthImage</servlet-class> </servlet> <servlet-mapping> <servlet-name>image</

Jsp+servlet 验证码案例

昨晚在csdn看到一位前辈写一个ajax+servlet+jsp验证.顿时心血来潮,在阅读前辈的代码下我亲手体验一下,做了一个验证码生成工具类.以供大家做个參考. 1:加入VeriyCodeUtils类生成验证码图像 package com.servlet; import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import java.awt.image.BufferedImage; import jav

登录验证码编写(jsp+servlet+dao)

一.什么是验证码及它的作用 验证码为全自动区分计算机和人类的图灵测试的缩写,是一种区分用户是计算机的公共全自动程序,这个问题可以由计算机生成并评判,但是必须只有人类才能解答. 可以防止恶意破解密码.刷票.论坛灌水.有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登录. 二.图文验证码的原理 在 servlet中随机生成一个指定位置的验证码,一般为四位,然后把该验证码保存到session中.在通过Java的绘图类以图片的形式输出该验证码. 为了增加验证码的安全级别,可以输出图片

jsp使用servlet实现验证码

在进行表单设计中,验证码的增加恰恰可以实现是否为“人为”操作,增加验证码可以防止网站数据库信息的冗杂等... 现在,小编将讲述通过servlet实现验证码: 验证码作为一个图片,在页面中为“画”出来的,它是如何画出来的呢? <生成图片> { 生成图片的类: 1.BufferedImage图像数据缓冲区 2.Graphics绘制图片 3.color获取颜色 4.Random获取随机数 5.ImageIO输出图片 } ////////////////////////////////////////

jsp+Servlet验证码及验证

一个用jsp+Servlet+jquery+ajax实现的验证码,及验证是否正确.供初学者学习交流. 效果图: 源代码: validate.jsp <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%  String path = request.getContextPath();  String basePath = request.ge

Web---图片验证码生成教程详解-从简单到复杂-从本地到前后台

首先,我们先来看本地如何生成图片验证码的,再来写输出到网页的验证码如何实现. 先来看最简单的-实现的功能是,将一个字符串变成图片写入到文件中 实现代码: package cn.hncu.img; import java.awt.Graphics; import java.awt.image.BufferedImage; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOE

基于Servlet的验证码实现

话不多说先上代码 public class VerCodeServlet extends HttpServlet { private static final long serialVersionUID = 5126616339795936447L; private ConfigurableCaptchaService configurableCaptchaService = null; private RandomFontFactory fontFactory = null; private