验证码思想:所谓验证码就是产生若干随机数,存放到session中,然后在servlet中获取session中的该值与页面输入值相比较,进而判断正误。
 
产生验证码的方法
随机数放在图片中,封装为一个JSP文件,并且将产生的验证码存放到session中。
 
刷新验证码的方法
方法一:点击验证码图片刷新:
验证码封装在JSP文件里,在表单中以图片的方式引入,代码如下:
<img id= "rightcode" src ="number.jsp" style=" cursor: pointer; vertical-align :middle;" onclick="javascript:this.src='number.jsp?'+Math.random()*10000;" />
点击换一张验证码,本质就是将验证码的src刷新一下,上一行代码中通过点击事件来刷新src.
方法二:可以在验证码后面加链接文字,通过JS实现点击刷新验证码的src。
如:
<script language= "JAVASCRIPT">
      /*点击换一张验证码,本质就是将验证码的src刷新一下*/
     function cg(){                                       
          document.getElementById( "rightcode" ).src = 'number2.jsp?' +Math.random()*10000;
     }
</ script>
<a href= "javascript:cg();">换一张 </a>
 
 
 
 
产生版本一验证码文件number.jsp代码如下:
<%@ page contentType= "image/jpeg" language ="java"
import="java.util.*,java.awt.*,java.awt.image.*,javax.imageio.*" pageEncoding= "utf-8"%>  
<%! 
    Color getRandColor( int fc,int bc){ 
        Random random = new Random(); 
        if(fc > 255){ 
            fc = 255; 
        } 
        if(bc < 255){ 
            bc = 255; 
        } 
        int r = fc +random.nextInt(bc-fc); 
        int g = fc +random.nextInt(bc-fc); 
        int b = fc +random.nextInt(bc-fc);          
        return new Color(r,g,b); 
    } 
%> 
 
<%  
    //设置页面不缓存 
    response.setHeader( "Pragma","no-cache" ); 
    response.setHeader( "Cache-Control","no-catch" ); 
    response.setDateHeader( "Expires",0); 
     
    //在内存中创建图象 
    int width = 60; 
    int height = 20; 
    BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB); 
     
    //创建图象 
    Graphics g = image.getGraphics(); 
    //生成随机对象 
    Random random = new Random(); 
    //设置背景色 
    g.setColor(getRandColor(200,250)); 
    g.fillRect(0,0,width,height); 
    //设置字体 
    g.setFont(new Font( "Tines Nev Roman",Font.PLAIN,18)); 
    //随机产生干扰线 
    g.setColor(getRandColor(160,200)); 
    for(int i = 0; i < 255; i++){ 
        int x = random.nextInt(width); 
        int y = random.nextInt(height); 
        int xl = random.nextInt(12); 
        int yl = random.nextInt(12); 
    } 
    //随机产生认证码,4位数字 
    String sRand = ""; 
    for(int i = 0; i < 4; i++){ 
        String rand = String.valueOf(random.nextInt(10)); 
        sRand  += rand; 
        //将认证码显示到图象中 
        g.setColor( new Color(20 + random.nextInt(110),20 + random.nextInt(110),20 + random.nextInt(110))); 
        g.drawString(rand,13*i+6,16); 
    } 
    /*把产生的验证码放到session中,在LoginServlet中获得该值与输入的验证码值进行比较*/
    session.setAttribute( "jpgCode",sRand); 
    //图像生效 
    g.dispose(); 
    //输出图像到页面 
    ImageIO.write(image,"JPEG" ,response.getOutputStream()); 
    out.clear(); 
    out = pageContext.pushBody(); 
%>
 
LoginServlet中获取值:
String incode = request.getParameter( "code");  
Object rightcode = request.getSession().getAttribute("jpgCode" );
进过比较二者的值是否一样,从而进行页面的跳转。 
 
 
产生版本二验证码文件number.jsp代码如下:
<%@ page language="java"  pageEncoding="UTF-8"   %>
<%@ page contentType= "image/jpeg" 
import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
<%!
    Color getRandColor( int fc, int bc) {//给定范围获得随机颜色
          Random random = new Random();
           if (fc > 255)
              fc = 255;
           if (bc > 255)
              bc = 255;
           int r = fc + random.nextInt(bc - fc);
           int g = fc + random.nextInt(bc - fc);
           int b = fc + random.nextInt(bc - fc);
           return new Color(r, g, b);
     }
%>
<%
     //设置页面不缓存
     response.setHeader( "Pragma", "No-cache" );
     response.setHeader( "Cache-Control", "no-cache" );
     response.setDateHeader( "Expires", 0);
 
     //生成随机验证码
     Random random = new Random();
     String sRand = "";
     for ( int i = 0; i < 4; i++) {
          String rand = String.valueOf(random.nextInt(10));
          sRand += rand;
     }
    /*把产生的验证码放到session中,在LoginServlet中获得该值与输入的验证码值进行比较*/
     session.setAttribute( "jpgCode", sRand);
 
     // 在内存中创建图象
     int width = 55;
     int height = 20;
     BufferedImage image = new BufferedImage(width, height,
              BufferedImage.TYPE_INT_RGB);
 
     // 获取图形上下文
     Graphics g = image.getGraphics();
 
     // 设定背景色
     g.setColor(getRandColor(200, 250));
     g.fillRect(0, 0, width, height);
 
     //设定字体
     g.setFont( new Font("serif" , Font.CENTER_BASELINE, 16));
 
     //画边框
     g.setColor( new Color(1));
     g.drawRect(0,0,width-1,height-1);
 
     // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
     g.setColor(getRandColor(160, 200));
     for ( int i = 0; i < 100; 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);
     }
 
     for ( int i = 0; i < 4; i++) {
          String rand = sRand.substring(i, i + 1);
           // 将认证码显示到图象中
          g.setColor( new Color(20 + random.nextInt(110), 20 + random
                   .nextInt(110), 20 + random.nextInt(110)));
           //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
          g.drawString(rand, 13 * i + 6, 16);
     }
 
     // 图象生效
     g.dispose();
 
     // 输出图象到页面
     try {
          ImageIO.write(image, "JPEG", response.getOutputStream());
     } catch (Exception e) {
     }
     out.clear();
     out = pageContext.pushBody();
%>
 
 
 
产生版本三验证码文件number.jsp代码同版本二:
在引用页面加刷新事件,可以点击刷新验证码。
部分代码如下:
<script language= "JAVASCRIPT">
      /*点击换一张验证码,本质就是将验证码的src刷新一下*/
     function cg(){                                       
          document.getElementById( "rightcode" ).src = 'number2.jsp?' +Math.random()*10000;
     }
</ script>
<div class= "field">
     <label>< span class ="red"> *</span>验证码 </label>
     <span>
         <input type= "text" name ="code" id="code" class="yzm">
         <img id= "rightcode" src="number.jsp" style=" cursor: pointer; vertical-align:middle ;" onclick="javascript:this.src='number.jsp?'+Math.random()*10000;" />
         <a href= "javascript:cg();">换一张 </a>
     </span>
</div>
 
 
 
 
 
 
 
 

Servlet程序中玩验证码的更多相关文章

  1. SSH实战 · SSH项目中怎么玩验证码

    大致思路与之前servlet中玩验证码类似,生成随机数,产生干扰线,画到图片上,保存到session中. 本人习惯用的时候专门写一个验证码的action:CheckImgAction. step1: ...

  2. 【转】在Eclipse中建立第一个Servlet程序

    转载地址:http://kin111.blog.51cto.com/738881/163354 继上篇在Eclipse中搭好了tomcat环境后,我们建立一个最简单的servlet程序,这个serve ...

  3. [Linux] PHP程序员玩转Linux系列-Nginx中的HTTPS

    1.PHP程序员玩转Linux系列-怎么安装使用CentOS 2.PHP程序员玩转Linux系列-lnmp环境的搭建 3.PHP程序员玩转Linux系列-搭建FTP代码开发环境 4.PHP程序员玩转L ...

  4. servlet中生成验证码

    在servlet中生成验证码 package login; import java.awt.Color; import java.awt.Graphics; import java.awt.image ...

  5. Servlet笔记2--模拟Servlet本质、第一个Servlet程序、将响应结果输出到浏览器中

    以下代码均非IDE开发,所以都不规范,仅供参考 模拟Servlet本质: 模拟Servlet接口: /* SUN公司制定的JavaEE规范:Servlet规范 Servlet接口是Servlet规范中 ...

  6. JAVA WEB项目中生成验证码及验证实例(附源码及目录结构)

    [我是一个初学者,自己总结和网上搜索资料,代码是自己敲了一遍,亲测有效,现将所有的目录结构和代码贴出来分享给像我一样的初学者] 作用 验证码为全自动区分计算机和人类的图灵测试的缩写,是一种区分用户是计 ...

  7. Servlet实现数字字母验证码图片(二)

    Servlet实现数字字母验证码图片(二): 生成验证码图片主要用到了一个BufferedImage类,如下:

  8. Web UI自动化测试中绕开验证码登陆方式浅谈

    web自动化测试中让测试者感到困惑的是登陆验证码,每次都不一样.现在推荐一种绕开验证码登陆的方式,其实就是将web浏览器获取的登陆cookie加载到程序中就可以了,这样程序就会认为你已经登陆,就可以跳 ...

  9. 可视化(番外篇)——在Eclipse RCP中玩转OpenGL

    最近在看有关Eclipse RCP方面的东西,鉴于Gephi是使用opengl作为绘图引擎,所以,萌生了在Eclipse RCP下添加画布,使用opengl绘图的想法,网上有博文详细介绍这方面的内容, ...

随机推荐

  1. Flex Layout Attribute

    GitHub: https://github.com/StefanKovac/flex-layout-attribute 引入基本的样式,可以更好的布局,可以在线制作: http://progress ...

  2. P87LPC760/61/62/64/67/68/69/78/79芯片解密单片机破解价格

    NXP恩智浦P87LPC760/61/62/64/67/68/69/78/79芯片解密单片机破解 NXP LPC700系列单片机解密型号: P87LPC759.P87LPC760.P87LPC761. ...

  3. Fiddler问题 - creation of the root certificate was not successful

    打开cmd执行命令. d: cd D:\soft\Fiddler2 makecert.exe -r -ss my -n "CN=DO_NOT_TRUST_FiddlerRoot, O=DO_ ...

  4. java.lang.NoSuchMethodException: org.apache.ibatis.executor.statement.StatementHandler.prepare(java.sql.Connection)

    此错误是由于版本造成的,如果使用mybatis3.4版本以上,配置拦截器规则应增加Intger @Intercepts({ @Signature( type= StatementHandler.cla ...

  5. ip二进制计算,与运算算网段

    每8位二进制,各位从左到右对应的权值分别是 128,64,32,16, 8,4,2,1 .(即2的n-1次方,n是从右到左当前位的位数)  所以随便拿一个256以内的数给你化为二进制,都可以分解为权值 ...

  6. css箭头

    .aui-list-item-arrow:before { content: ''; width: 0.4rem; height: 0.4rem; position: absolute; top: 5 ...

  7. 【原】iOS学习之Quartz2D(1)

    什么是Quartz2D 1.Quartz 2D 是一个二维绘图引擎,同时支持iOS和Mac系统 2.Quartz 2D 能完成的工作: 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成 ...

  8. 面向对象课后深入学习(C++ 类的静态成员详细讲解)

    今天在刚申请了博客,一下午都在写那个随笔,所以说好的来看c++的也放在了最后,下星期就考试了,这个类的静态成员是我不是很懂的,在网上 看到一片很详细的博客考下来回去慢慢看. 在C++中,静态成员是属于 ...

  9. Django 中related_name,"%(app_label)s_%(class)s_related"

    先看个model from django.db import models # Create your models here. class Parent(models.Model): name = ...

  10. Linux Shell 通配符、元字符、转义符【转帖】

    作者:程默 说到shell通配符(wildcard),大家在使用时候会经常用到.下面是一个实例: 1   1 2 3 4 [chengmo@localhost ~/shell]$ ls a.txt  ...