首页 java开发 Java Servlet实现验证码

Java Servlet实现验证码

[2019-03-07 14:25 类别:java开发 阅读(292) ]

1  实现步骤

1.1  验证码基本概念

验证码包含两部分:

  • 输入框

  • 显示验证码的图片

网页显示验证码:

<input type="text id="verifyCode" name="verifyCode" size="6"/>
<img alt="验证码" id="safecode" src="<%=request.getComtextPath()%>/servlet/ImageServlet">

1.2  生成图片

生成图片用到的类

  • BufferedImage图像数据缓冲区

  • Graphice绘制图片

  • Color获取颜色

  • Random生成随机数

  • ImageIO输出图片

1.3  生成图片的实现类

ImageServlet类

  1. 定义BufferedImage对象

  2. 获得Graphice对象

  3. 通过Random产生随机验证码信息

  4. 使用Graphice绘制图片

  5. 记录验证码信息到session中

  6. 使用ImageIO输出图片

1.4  校验验证码是否正确

LoginServlet类

  1. 获取页面验证码

  2. 获取session保存的验证码

  3. 比较验证码

  4. 返回校验结果

blob.png

2  代码实现

注意:需要将相关jar包导入项目

主页面代码(index.jsp)

<script type="text/javascript">     
function reloadCode(){       
var time = new Date().getTime();         
document.getElementById("imagecode").src="<%=request.getContextPath() %>/servlet/ImageServlet?d="+time;} 
</script>
<body>
    <form action="<%=request.getContextPath() %>/servlet/LoginServlet" method="get">
        验证码:<input type="text" name="checkcode"/>
        <img alt="验证码" id="imagecode" src="<%=request.getContextPath() %>/servlet/ImageServlet"/>
        <a href="javascript: reloadCode();">看不清楚</a><br>
        <input type="submit" value="提交">
    </form>
</body>

生成图片的Java代码

package com.muke;

import java.awt.Color;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ImageServlet extends HttpServlet {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException{
        BufferedImage bi = new BufferedImage(68,22,BufferedImage.TYPE_INT_RGB);//长度,宽度,图片类型
        Graphics g = bi.getGraphics();//画一个图片
        Color c = new Color(200,150,255);//定义背景颜色
        g.setColor(c);
        g.fillRect(0, 0, 68, 22);//背景框(坐标)
        
        char[] ch = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".toCharArray();//把字母和数字全部列出来
        Random r = new Random();//随机数类
        int len=ch.length,index;//获取数组长度和index随机数
        StringBuffer sb = new StringBuffer();//保存随机字符的一个类
        for(int i=0; i<4; i++){//取四位随机数
            index = r.nextInt(len);//获取一个随机数(数组长度范围之内)
            g.setColor(new Color(r.nextInt(88),r.nextInt(188),r.nextInt(255)));//随机获得一个颜色
            g.drawString(ch[index]+"", (i*15)+3, 18);//把字符画到图片上//字符  x坐标  y坐标
            sb.append(ch[index]);//保存随机字符
        }
        request.getSession().setAttribute("piccode", sb.toString());
        ImageIO.write(bi, "JPG", response.getOutputStream());//输出//对象  类型  输出位置
    }
}

验证输入的Java代码

package com.muke;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class LoginServlet extends HttpServlet{

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException{
        
        String piccode = (String) request.getSession().getAttribute("piccode");
        String checkcode = request.getParameter("checkcode");
        checkcode = checkcode.toUpperCase();
        response.setContentType("text/html;charset=gbk");
        PrintWriter out = response.getWriter();
        if(checkcode.equals(piccode)){
            out.println("验证码输入正确!");
        }else{
            out.println("验证码输入错误!!!");
        }
        out.flush();
        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>
        <servlet-name>ImageServlet</servlet-name>
        <servlet-class>com.muke.ImageServlet</servlet-class>
    </servlet>
    <servlet>
        <servlet-name>LoginServlet</servlet-name>
        <servlet-class>com.muke.LoginServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>ImageServlet</servlet-name>
        <url-pattern>/servlet/ImageServlet</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>LoginServlet</servlet-name>
        <url-pattern>/servlet/LoginServlet</url-pattern>
    </servlet-mapping>
    
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
</web-app>

3  结果输出


blob.png

blob.png

blob.png

关于博主Jansens