zoukankan      html  css  js  c++  java
  • servlet 产生验证码

      在网上每次注册或者登录的时候都要求用户输入验证码,今天我们来做一个吧。

      

        private static final long serialVersionUID = 1L;
      //用数组CHARs数组来保存所有能够产生的字符
    public static final char[] CHARs={
    '2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','J','K','L','M','N','P','Q','R','S','T','U','V','W','X','Y','Z'
    };
    public static Random random=new Random();
      //下面是产生六个随机数
    public static String getRandomString(){
    StringBuffer buffer=new StringBuffer();
    for(int i=0;i<6;i++){
    buffer.append(CHARs[random.nextInt(CHARs.length)]);
    }
    return buffer.toString();
    }
      //用三个随机数来分别产生RGB的数值
    public static Color getRandomColor(){
    return new Color(random.nextInt(255),random.nextInt(255),random.nextInt(255));
    }
      //产生反色的颜色
    public static Color getgetReverseColor(Color c){
    return new Color(255-c.getRed(),255-c.getGreen(),255-c.getBlue());

    }
    public void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {

    response.setContentType("image/jpeg");//生成时的图像格式

    String randomString=getRandomString();//获取随机数
    request.getSession(true).setAttribute("randomString", randomString);
        //生成的验证码图像的大小
    int width=100;
    int height=30;
    Color color=getRandomColor();
    Color reverse=getgetReverseColor(color);
        
    BufferedImage bi=new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
    Graphics2D g=bi.createGraphics();
    g.setFont(new Font(Font.SANS_SERIF,Font.BOLD,16));
    g.setColor(color);
    g.fillRect(0, 0, width, height);
    g.setColor(reverse);
    g.drawString(randomString, 18, 20);
        //用来产生污点来防止被破解
    for(int i=0,n=random.nextInt(100);i<n;i++){
    g.drawRect(random.nextInt(width), random.nextInt(height), 1, 1);

    }
    ServletOutputStream out=response.getOutputStream();
    JPEGImageEncoder encoder=JPEGCodec.createJPEGEncoder(out);
    encoder.encode(bi);
    out.flush();
    }

    用一个HTML来测试结果

    <!DOCTYPE html>
    <html>
    <head>
    <script type="text/javascript">
    function reloadImage(){
    document.getElementById(
    'identity').src='servlet/IdentityServlet?ts='+new Date().getTime();
    }
    </script>
    <img src="servlet/IdentityServlet" id="identity"/>
    <input type="button" value="换个图片" onclick="reloadImage()" id="btn">
    </head>

    <body>

    </body>
    </html>



  • 相关阅读:
    JVM源码分析之Object.wait/notify(All)完全解读
    进程无故消失的破案历程
    Jmeter——JDBC Connection Configuration参数化
    Jmeter——CSV DataSet Config参数化
    WeTest明星工具-移动端性能测试PerfDog初探
    基于appium实现的线性代码引用unittest单元测试框架
    Requests实践详解
    Appium-Server与Appium-Desktop的区别
    Appium Python API 中文版
    单元测试框架Uinttest一文详解
  • 原文地址:https://www.cnblogs.com/tianyake/p/2420202.html
Copyright © 2011-2022 走看看