zoukankan      html  css  js  c++  java
  • JSP验证码

    验证码产生页面放在image.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
        session.setAttribute("CHECK_NUMBER_KEY", 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();
    %>

    引用页面用img元素包含,通过JS代码控制器

    <img id="checkNumImage"    align="absmiddle" title="换一张" style="height:25px;cursor:pointer;"/>
       //1.处理验证码的更换问题,采用的方法就是在连接地址后面加一个timeStamp参数,让它随时间改变,这样导致就是连接地址也发生了改变,就打到了点击验证码改变的效果
    function changeCheckNum(){ 
    var $img = $("img[id='checkNumImage']") ;
      $img.attr(
    "src","${basePath}/jsp/image.jsp?timeStamp="+new Date().getTime() );
    }
    $("#checkNumImage").bind("click",function(){
                changeCheckNum();
    });
  • 相关阅读:
    JQuery源码解析(九)
    JQuery源码分析(八)
    C#的扩展方法解析
    JQuery基础DOM操作
    Ajax中的eval函数的用法
    EF上下文管理
    Asp.Net请求管道中的19个事件
    JQuery源码分析(七)
    SoftReference、WeakReference、PhantomRefrence分析和比较
    php 计算gps坐标 距离
  • 原文地址:https://www.cnblogs.com/liaojie970/p/4897349.html
Copyright © 2011-2022 走看看