jquery实现无刷新验证码的简单实例


Posted in Javascript onMay 19, 2016

1. 思路:

页面上的验证码图片是servlet,采用jquery实现异步校验信息

2. 所用到的文件

VerifyCodeServlet.java   --用于生成图片的servlet

ResultServlet.java          --用于校验验证码正确性的servlet

verifyCode.js                  --校验的js文件

jquery.js                         --jquery包里的源文件

verifyCode.jsp                --页面

3. 代码

VerifyCodeServlet.java

Java代码

import java.awt.Color;  
import java.awt.Font;  
import java.awt.Graphics2D;  
import java.awt.image.BufferedImage;  
import java.util.Random;  
  
import javax.imageio.ImageIO;  
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;  
  
public class VerifyCodeServlet extends HttpServlet {  
  
  // 验证码图片的宽度。  
  private int width = 60;  
  
  // 验证码图片的高度。  
  private int height = 20;  
  
  // 验证码字符个数  
  private int codeCount = 4;  
  
  private int x = 0;  
  
  // 字体高度  
  private int fontHeight;  
  
  private int codeY;  
  
  char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',  
      'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',  
      'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };  
  
  /**  
   * 初始化验证图片属性  
   */  
  public void init() throws ServletException {  
    // 从web.xml中获取初始信息  
    // 宽度  
    String strWidth = this.getInitParameter("width");  
    // 高度  
    String strHeight = this.getInitParameter("height");  
    // 字符个数  
    String strCodeCount = this.getInitParameter("codeCount");  
  
    // 将配置的信息转换成数值  
    try {  
      if (strWidth != null && strWidth.length() != 0) {  
        width = Integer.parseInt(strWidth);  
      }  
      if (strHeight != null && strHeight.length() != 0) {  
        height = Integer.parseInt(strHeight);  
      }  
      if (strCodeCount != null && strCodeCount.length() != 0) {  
        codeCount = Integer.parseInt(strCodeCount);  
      }  
    } catch (NumberFormatException e) {  
    }  
  
    x = width / (codeCount + 1);  
    fontHeight = height - 2;  
    codeY = height - 4;  
  
  }  
  
  protected void service(HttpServletRequest req, HttpServletResponse resp)  
      throws ServletException, java.io.IOException {  
  
    // 定义图像buffer  
    BufferedImage buffImg = new BufferedImage(width, height,  
        BufferedImage.TYPE_INT_RGB);  
    Graphics2D g = buffImg.createGraphics();  
  
    // 创建一个随机数生成器类  
    Random random = new Random();  
  
    // 将图像填充为白色  
    g.setColor(Color.WHITE);  
    g.fillRect(0, 0, width, height);  
  
    // 创建字体,字体的大小应该根据图片的高度来定。  
    Font font = new Font("Fixedsys", Font.PLAIN, fontHeight);  
    // 设置字体。  
    g.setFont(font);  
  
    // 画边框。  
    g.setColor(Color.BLACK);  
    g.drawRect(0, 0, width - 1, height - 1);  
  
    // 随机产生160条干扰线,使图象中的认证码不易被其它程序探测到。  
    g.setColor(Color.BLACK);  
    for (int i = 0; i < 160; i++) {  
      int x = random.nextInt(width);  
      int y = random.nextInt(height);  
      int xl = random.nextInt(12);  
      int yl = random.nextInt(12);  
      g.drawLine(x, y, x + xl, y + yl);  
    }  
  
    // randomCode用于保存随机产生的验证码,以便用户登录后进行验证。  
    StringBuffer randomCode = new StringBuffer();  
    int red = 0, green = 0, blue = 0;  
  
    // 随机产生codeCount数字的验证码。  
    for (int i = 0; i < codeCount; i++) {  
      // 得到随机产生的验证码数字。  
      String strRand = String.valueOf(codeSequence[random.nextInt(36)]);  
      // 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。  
      red = random.nextInt(255);  
      green = random.nextInt(255);  
      blue = random.nextInt(255);  
  
      // 用随机产生的颜色将验证码绘制到图像中。  
      g.setColor(new Color(red, green, blue));  
      g.drawString(strRand, (i + 1) * x, codeY);  
  
      // 将产生的四个随机数组合在一起。  
      randomCode.append(strRand);  
    }  
    // 将四位数字的验证码保存到Session中。  
    HttpSession session = req.getSession();  
    session.setAttribute("validateCode", randomCode.toString());  
  
    // 禁止图像缓存。  
    resp.setHeader("Pragma", "no-cache");  
    resp.setHeader("Cache-Control", "no-cache");  
    resp.setDateHeader("Expires", 0);  
  
    resp.setContentType("image/jpeg");  
  
    // 将图像输出到Servlet输出流中。  
    ServletOutputStream sos = resp.getOutputStream();  
    ImageIO.write(buffImg, "jpeg", sos);  
    sos.close();  
  }  
  
} 
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.util.Random;

import javax.imageio.ImageIO;
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;

public class VerifyCodeServlet extends HttpServlet {

 // 验证码图片的宽度。
 private int width = 60;

 // 验证码图片的高度。
 private int height = 20;

 // 验证码字符个数
 private int codeCount = 4;

 private int x = 0;

 // 字体高度
 private int fontHeight;

 private int codeY;

 char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
  'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
  'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };

 /**
 * 初始化验证图片属性
 */
 public void init() throws ServletException {
 // 从web.xml中获取初始信息
 // 宽度
 String strWidth = this.getInitParameter("width");
 // 高度
 String strHeight = this.getInitParameter("height");
 // 字符个数
 String strCodeCount = this.getInitParameter("codeCount");

 // 将配置的信息转换成数值
 try {
  if (strWidth != null && strWidth.length() != 0) {
  width = Integer.parseInt(strWidth);
  }
  if (strHeight != null && strHeight.length() != 0) {
  height = Integer.parseInt(strHeight);
  }
  if (strCodeCount != null && strCodeCount.length() != 0) {
  codeCount = Integer.parseInt(strCodeCount);
  }
 } catch (NumberFormatException e) {
 }

 x = width / (codeCount + 1);
 fontHeight = height - 2;
 codeY = height - 4;

 }

 protected void service(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, java.io.IOException {

 // 定义图像buffer
 BufferedImage buffImg = new BufferedImage(width, height,
  BufferedImage.TYPE_INT_RGB);
 Graphics2D g = buffImg.createGraphics();

 // 创建一个随机数生成器类
 Random random = new Random();

 // 将图像填充为白色
 g.setColor(Color.WHITE);
 g.fillRect(0, 0, width, height);

 // 创建字体,字体的大小应该根据图片的高度来定。
 Font font = new Font("Fixedsys", Font.PLAIN, fontHeight);
 // 设置字体。
 g.setFont(font);

 // 画边框。
 g.setColor(Color.BLACK);
 g.drawRect(0, 0, width - 1, height - 1);

 // 随机产生160条干扰线,使图象中的认证码不易被其它程序探测到。
 g.setColor(Color.BLACK);
 for (int i = 0; i < 160; i++) {
  int x = random.nextInt(width);
  int y = random.nextInt(height);
  int xl = random.nextInt(12);
  int yl = random.nextInt(12);
  g.drawLine(x, y, x + xl, y + yl);
 }

 // randomCode用于保存随机产生的验证码,以便用户登录后进行验证。
 StringBuffer randomCode = new StringBuffer();
 int red = 0, green = 0, blue = 0;

 // 随机产生codeCount数字的验证码。
 for (int i = 0; i < codeCount; i++) {
  // 得到随机产生的验证码数字。
  String strRand = String.valueOf(codeSequence[random.nextInt(36)]);
  // 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。
  red = random.nextInt(255);
  green = random.nextInt(255);
  blue = random.nextInt(255);

  // 用随机产生的颜色将验证码绘制到图像中。
  g.setColor(new Color(red, green, blue));
  g.drawString(strRand, (i + 1) * x, codeY);

  // 将产生的四个随机数组合在一起。
  randomCode.append(strRand);
 }
 // 将四位数字的验证码保存到Session中。
 HttpSession session = req.getSession();
 session.setAttribute("validateCode", randomCode.toString());

 // 禁止图像缓存。
 resp.setHeader("Pragma", "no-cache");
 resp.setHeader("Cache-Control", "no-cache");
 resp.setDateHeader("Expires", 0);

 resp.setContentType("image/jpeg");

 // 将图像输出到Servlet输出流中。
 ServletOutputStream sos = resp.getOutputStream();
 ImageIO.write(buffImg, "jpeg", sos);
 sos.close();
 }

}

ResultServlet.java

Java代码

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;  
  
public class ResultServlet extends HttpServlet {  
  
  /**  
   * The doGet method of the servlet. <br>  
   *  
   * This method is called when a form has its tag value method equals to get.  
   *  
   * @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 doGet(HttpServletRequest request, HttpServletResponse response)  
      throws ServletException, IOException {  
  
    doPost(request, response);  
  }  
  
  /**  
   * 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 {  
  
    response.setContentType("text/html;charset=utf-8");  
    String validateC = (String) request.getSession().getAttribute("validateCode");  
    String veryCode = request.getParameter("c");  
    PrintWriter out = response.getWriter();  
    if(veryCode==null||"".equals(veryCode)){  
      out.println("验证码为空");  
    }else{  
      if(validateC.equals(veryCode)){  
        out.println("验证码正确");  
      }else{  
        out.println("验证码错误");  
      }  
    }  
    out.flush();  
    out.close();  
  }  
  
} 
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;

public class ResultServlet extends HttpServlet {

 /**
 * The doGet method of the servlet. <br>
 *
 * This method is called when a form has its tag value method equals to get.
 * 
 * @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 doGet(HttpServletRequest request, HttpServletResponse response)
  throws ServletException, IOException {

 doPost(request, response);
 }

 /**
 * 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 {

 response.setContentType("text/html;charset=utf-8");
 String validateC = (String) request.getSession().getAttribute("validateCode");
 String veryCode = request.getParameter("c");
 PrintWriter out = response.getWriter();
 if(veryCode==null||"".equals(veryCode)){
  out.println("验证码为空");
 }else{
  if(validateC.equals(veryCode)){
  out.println("验证码正确");
  }else{
  out.println("验证码错误");
  }
 }
 out.flush();
 out.close();
 }

}

verifyCode.js

Js代码

function changeImg(){  
  var imgSrc = $("#imgObj");  
  var src = imgSrc.attr("src");  
  imgSrc.attr("src",chgUrl(src));  
}  
//时间戳  
//为了使每次生成图片不一致,即不让浏览器读缓存,所以需要加上时间戳  
function chgUrl(url){  
  var timestamp = (new Date()).valueOf();  
  url = url.substring(0,17);  
  if((url.indexOf("&")>=0)){  
    url = url + "×tamp=" + timestamp;  
  }else{  
    url = url + "?timestamp=" + timestamp;  
  }  
  return url;  
}  
  
function isRightCode(){  
  var code = $("#veryCode").attr("value");  
  code = "c=" + code;  
  $.ajax({  
    type:"POST",  
    url:"resultServlet",  
    data:code,  
    success:callback  
  });  
}  
  
function callback(data){  
  $("#info").html(data);  
} 
function changeImg(){
 var imgSrc = $("#imgObj");
 var src = imgSrc.attr("src");
 imgSrc.attr("src",chgUrl(src));
}
//时间戳
//为了使每次生成图片不一致,即不让浏览器读缓存,所以需要加上时间戳
function chgUrl(url){
 var timestamp = (new Date()).valueOf();
 url = url.substring(0,17);
 if((url.indexOf("&")>=0)){
 url = url + "×tamp=" + timestamp;
 }else{
 url = url + "?timestamp=" + timestamp;
 }
 return url;
}

function isRightCode(){
 var code = $("#veryCode").attr("value");
 code = "c=" + code;
 $.ajax({
 type:"POST",
 url:"resultServlet",
 data:code,
 success:callback
 });
}

function callback(data){
 $("#info").html(data);
}

verifyCode.jsp

Html代码

<%@ 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">  
    <script type="text/javascript" src="js/verifyCode.js"></script>  
    <script type="text/javascript" src="js/jquery.js"></script>  
    <title>test verify code</title>  
  </head>  
  <body>  
    <input id="veryCode" name="veryCode" type="text"/>  
    <img id="imgObj" alt="" src="verifyCodeServlet"/>  
    <a href="#" onclick="changeImg()">换一张</a>  
    <input type="button" value="验证" onclick="isRightCode()"/>  
    <div id="info"></div>  
  </body>  
</html>

以上这篇jquery实现无刷新验证码的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
通过JAVASCRIPT读取ASP设定的COOKIE
Nov 24 Javascript
JavaScript 应用类库代码
Jun 02 Javascript
Javascript 面向对象(二)封装代码
May 23 Javascript
jQuery之选择组件的深入解析
Jun 19 Javascript
js鼠标点击图片切换效果实现代码
Nov 19 Javascript
使用vue实现点击按钮滑出面板的实现代码
Jan 10 Javascript
jQuery实现三级联动效果
Mar 02 Javascript
详谈jQuery中的一些正则匹配表达式
Mar 08 Javascript
Vue 3.x+axios跨域方案的踩坑指南
Jul 04 Javascript
策略模式实现 Vue 动态表单验证的方法
Sep 16 Javascript
layui--select使用以及下拉框实现键盘选择的例子
Sep 24 Javascript
js DOM的事件常见操作实例详解
Dec 16 Javascript
AngularJs解决跨域问题案例详解(简单方法)
May 19 #Javascript
JavaScript:Array类型全面解析
May 19 #Javascript
JavaScript:Date类型全面解析
May 19 #Javascript
javascript中对Date类型的常用操作小结
May 19 #Javascript
JS Attribute属性操作详解
May 19 #Javascript
jQuery点击输入框显示验证码图片
May 19 #Javascript
Bootstrap教程JS插件滚动监听学习笔记分享
May 18 #Javascript
You might like
咖啡豆要不要放冰箱的原因
2021/03/04 冲泡冲煮
PHP 上传文件大小限制
2009/07/05 PHP
php设计模式 Composite (组合模式)
2011/06/26 PHP
控制PHP的输出:缓存并压缩动态页面
2013/06/11 PHP
thinkphp3查询mssql数据库乱码解决方法分享
2014/02/11 PHP
Linux系统中设置多版本PHP共存配合Nginx服务器使用
2015/12/21 PHP
老司机传授Ubuntu下Apache+PHP+MySQL环境搭建攻略
2016/03/20 PHP
php读取XML的常见方法实例总结
2017/04/25 PHP
js 目录列举函数
2008/11/06 Javascript
jQuery实用技巧必备(上)
2015/11/02 Javascript
JS实现的多张图片轮流播放幻灯片效果
2016/07/22 Javascript
javascript正则表达式模糊匹配IP地址功能示例
2017/01/06 Javascript
Javascript中return的使用与闭包详解
2017/01/11 Javascript
微信小程序 数据交互与渲染实例详解
2017/01/21 Javascript
vue.js计算属性computed用法实例分析
2018/07/06 Javascript
jQuery实现左右两个列表框的内容相互移动功能示例
2019/01/27 jQuery
node.js使用express框架进行文件上传详解
2019/03/03 Javascript
jquery实现的分页显示功能示例
2019/08/23 jQuery
详解Vue Cli浏览器兼容性实践
2020/06/08 Javascript
仅用50行代码实现一个Python编写的计算器的教程
2015/04/17 Python
Windows中使用wxPython和py2exe开发Python的GUI程序的实例教程
2016/07/11 Python
使用Python脚本和ADB命令实现卸载App
2017/02/10 Python
Python中defaultdict与lambda表达式用法实例小结
2018/04/09 Python
使用Selenium破解新浪微博的四宫格验证码
2018/10/19 Python
Python字符串处理的8招秘籍(小结)
2019/08/13 Python
Django之使用内置函数和celery发邮件的方法示例
2019/09/16 Python
Python计算两个矩形重合面积代码实例
2019/09/16 Python
CSS3——齿轮转动关键代码
2013/05/02 HTML / CSS
乌克兰网上珠宝商店:GoldSoveren
2020/03/31 全球购物
药品质量检测应届生求职信
2013/11/14 职场文书
班级学习计划书
2014/04/27 职场文书
2015年度培训工作总结范文
2015/04/02 职场文书
加薪通知
2015/04/25 职场文书
志愿者服务活动总结报告
2015/05/06 职场文书
《狼王梦》读后感:可怜天下父母心
2019/11/01 职场文书
Java8利用Stream对列表进行去除重复的方法详解
2022/04/14 Java/Android