• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >jquery > jquery实现无刷新验证码的简单实例

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

作者: 字体:[增加 减小] 来源:互联网

通过本文主要向大家介绍了jquery登录验证码等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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 = rand



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 到处都是jQuery选择器的年代 不了解它们的性能,行吗
  • jQuery中extend()和fn.extend()方法详解
  • 浅谈jQuery中对象遍历.eq().first().last().slice()方法
  • jQuery.form.js的使用详解
  • jQuery对象的selector属性用法实例
  • JQuery 获取和设置Select选项的代码
  • jQuery实现滑动页面固定顶部显示(可根据显示位置消失与替换)
  • JQuery验证jsp页面属性是否为空(实例代码)
  • jquery 页面滚动到指定DIV实现代码
  • jQuery validate插件功能与用法详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • jQuery获取及设置表单input各种类型值的方法小结
    • jquery键盘事件使用介绍
    • jQuery截取指定长度字符串代码
    • 简洁Ajax函数处理(示例代码)
    • 从jquery的过滤器.filter()方法想到的
    • Jquery iframe内部出滚动条
    • jquery和ajax的关系详细介绍
    • 关于jquery css的使用介绍
    • jquery实现的伪分页效果代码
    • JQuery选择器特辑 详细小结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有