16.随机验证码的生成及使用,全编码编写

使用技术:

JSP + Ajax

随机生成验证码,动态验证。

功能:随机生成验证码,存入会话,生成验证码图片,供输入验证,

若验证成功,提示:验证码输入成功,并且将注册按钮启用;

若验证失败,提示:验证码输入错误,并且将注册按钮禁用,并且在会话中删除缓存的验证码数据。

若会话中没有存储验证码数据,则提醒:验证码已失效,点击刷新。

验证码点击可以刷新

1、验证码输入成功

image.png

2、验证码输入失败

image.png

验证码输入失败

3、验证码失效

image.png

验证码失效

代码:

1、 随机生成验证码代码,VerificationCodeServlet.java:

package com.company.project.servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.sun.prism.Image;

@WebServlet("/verification-code-servlet")
public class VerificationCodeServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
    
    //设置生成验证码的画布宽度
    int w = 80;
    //生成验证码的长度
    int fontNum = 4;
    
    //验证码字体大小
    int fontSize = (w - 10) / fontNum;
    
    //根据字体大小设置画布的高度
    int h = (int) (fontSize * 1.5);
    
    //初始化字符源
    String charSource = "abcdefghijklmnopqrstuvwxyxABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
    
    /**
     * 随机生成验证码
     * @param num 生成验证码的长度
     * @return 验证码
     */
    public String randString(int num) {
        String verCode = "";
        for(int i = 0;i<num;i++) {
            verCode += charSource.charAt((int)(Math.random()*charSource.length()));
        }
        System.out.println("verCode:"+verCode);
        return verCode;
    }
    
    public Color randColor() {
        int r = (int)(Math.random() * 256);
        int g = (int)(Math.random() * 256);
        int b = (int)(Math.random() * 256);
        
        Color color = new Color(r, g, b);
        
        System.out.println("color:"+color);
        return color;
    }
    
    /**
     * 随机生成一条直线
     * @return 两点坐标(x1,y1)(x2,y2)
     */
    public int[] randLine() {
        int x1,x2,y1,y2;
        x1 = (int)(Math.random()*w);
        x2 = (int)(Math.random()*w);
        y1 = (int)(Math.random()*h);
        y2 = (int)(Math.random()*h);
        int[] result = {x1,y1,x2,y2};
        return result;
    }
    
    public VerificationCodeServlet() {
        super();
    }


    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //初始化画布
        BufferedImage canvas = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB);
        
        //初始化画笔对象
        Graphics pen = canvas.getGraphics();
        
        //设置画笔颜色
        pen.setColor(Color.WHITE);
        
        //画一个填充矩形
        pen.fillRect(0, 0, w, h);
        
        //设置画笔颜色
        pen.setColor(Color.black);
        
        //画出边框
        pen.drawRect(0, 0, w-1, h-1);
        
        //设置画笔字体样式
        pen.setFont(new Font("微软雅黑", Font.BOLD, fontSize));
        
        
        //生成验证码字符串
        String verCode = randString(fontNum);
        
        //将生成的验证码存入会话
        request.getSession().setAttribute("verCode", verCode);
        
        //绘制随机验证码
        for(int i = 0;i<verCode.length();i++) {
            pen.setColor(randColor());
            pen.drawString(String.valueOf(verCode.charAt(i)), 10 + i * 15, (h + fontSize) /2);
        }
        
        //绘制一条随机直线
        int[] line = randLine();  
        for(int i = 0;i<line.length;i++) {
            System.out.println(line[i]);
        }
        
        
        //设置画笔字体样式
        pen.setColor(Color.BLACK);
        
        //画出随机直线
        pen.drawLine(line[0],line[1],line[2],line[3]);
        
        //获取输出流对象
        ServletOutputStream out = response.getOutputStream();
        
        //把画好的验证码写入输出流
        ImageIO.write(canvas, "png", out);
        
        //释放输出流
        out.flush();
        out.close();
        
    }


    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        
    }
}

2、验证码认证,VerifyServlet.java

package com.company.project.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Enumeration;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/verify-servlet")
public class VerifyServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       

    public VerifyServlet() {
        super();
        
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        response.setCharacterEncoding("utf-8");
        request.setCharacterEncoding("utf-8");
        String verCode = request.getParameter("verCode");
        System.out.println("-----------------");
        
        String flag = null ;
        String code = (String) request.getSession().getAttribute("verCode");
        
        if(code==null) {
            //验证码失效
            flag = "0";
        }
        else if(verCode.toUpperCase().equals(code.toUpperCase())) {
            //验证码输入正确
            flag = "1";
        }else {
            //验证码输入失败
            flag = "2";
            request.getSession().removeAttribute("verCode");
        }       
        PrintWriter out=response.getWriter();
        out.print(flag);
    }


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

}

3、验证码页面,verCode.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>登录</title>
        <script>
            var baseUrl = "http://localhost:8888/JavaEE17Demo/verify-servlet";
            var xmlHttp;
            var responseText;
            var onBlurId;
            var code;       
    
            //创建创建 XMLHttp 对象
            function createXmlHttp(name, value) {
                if(window.ActiveXObject) {
                    console.log("操作提示:您的浏览器是IE浏览器。");
                    xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
                } else if(window.XMLHttpRequest) {
                    console.log("操作提示:您的浏览器不是IE浏览器。");
                    xmlHttp = new XMLHttpRequest();
                }

                //注册监听或者回调函数
                xmlHttp.onreadystatechange = callback;
                //1:打开状态
                //传递参数
                var url = baseUrl + "?" + name + "=" + value;
                //GET方法打开,第三个参数如果为true,那么为异步请求,将不会刷新整个页面.
                xmlHttp.open("GET", url, true);
                //2:发送状态
                //Get方式的send()
                xmlHttp.send(null);

            }

            //回调函数,处理响应信息
            function callback() {

                //获取响应内容
                if(xmlHttp.readyState == 4) {
                    if(xmlHttp.status == 200) {
                        responseText = xmlHttp.responseText;
                        console.log(responseText);
                        var pText = document.getElementById("pText");
                        var button = document.getElementById("regButton");
                    
                        if(responseText == "0") {
                            pText.style.color = "red";
                            button.disabled = true;
                        
                            pText.innerHTML="验证码已失效,点击刷新";
                        } else if(responseText == "1") {
                            pText.style.color = "green";
                            button.disabled = false;
                            pText.innerHTML="验证码输入成功";
                        }else{
                            pText.style.color = "red";
                            button.disabled = true;
                            pText.innerHTML="验证码输入失败";
                        }

                    }
                }
            }

            //通过处理后的响应信息修改提醒文本
            function setResponseText(text) {
                var id;
                var responseText;
                
            }

            //重写失去焦点事件
            function onBlur(id) {
                var module = document.getElementById(id);
                var name = module.name;
                var value = module.value;
                //var url = baseUrl + "?" + name + "=" + value;
                onBlurId = id;
                console.log(name + "失去焦点");
                console.log(name + ":" + value);
                createXmlHttp(name, value);
            }
            
            function onClick(){
                var id = Math.floor(Math.random()*10);
                code = document.getElementById("verCodeImg");
                console.log(code);
                code.src = "http://localhost:8888/JavaEE17Demo/verification-code-servlet"+"?id="+id;
                console.log(code.src);
            }
        </script>
    </head>

    <body>
        <form id="Login" action="" method="post">
            <table>
                <tr>
                    <td>邮箱:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input name="e-mail" id="e-mail" type="text"  /></td>
                    <td>
                        <p id="pText1" style="color: red;"></p>
                    </td>
                </tr>
                <tr>
                    <td>手机号: <input name="phoneNum" type="text" id="phoneNum"  /></td>
                    <td>
                        <p id="pText2" style="color: red;"></p>
                    </td>
                </tr>
                <tr>
                    <td>验证码: <input type="text"  id="verCode" name="verCode" onblur="onBlur(id)"/></td>
                    <td><img id="verCodeImg" alt="随机生成验证码" src="http://localhost:8888/JavaEE17Demo/verification-code-servlet" onclick="onClick()" ></td>
                    <td>
                        <p id="pText" style="color: red;"></p>
                    </td>
                </tr>
            </table>
            
            <input type="button" id="regButton" value="注册" disabled="true"/>
        </form>
    </body>

</html>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容