zoukankan      html  css  js  c++  java
  • 编写生成彩色验证码的Servlet

         利用Ajax实现无刷新的彩色验证码时,也需要编写一个名称为PictureCheckCode.java的Servlet,该类继承HttpServlet,主要通过service()方法生成验证码。

         下面将介绍在service()方法中生成彩色验证码的具体过程。

       (1)设置响应头信息并指定生成的响应是JPG图片,具体代码       

    //禁止缓存

    response.setHeader("Pragma", "No-cache");

    response.setHeader("Cache-Control", "No-cache");

    response.setDateHeader("Expires", 0);

    // 指定生成的响应是图片

    response.setContentType("image/jpeg");

    (2)创建用于生成验证码的绘图类对象,并绘制一个填色矩形作为验证码的背景,具体代码如下:

    int width = 200;

    int height = 60;

    //创建BufferedImage类的对象

    BufferedImage image = new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);

    Graphics g = image.getGraphics(); //创建Graphics类的对象

    Graphics2D g2d=(Graphics2D)g; //通过Graphics类的对象创建一个Graphics2D类的对象

    Random random = new Random(); //实例化一个Random对象

    Font mFont = new Font("华文宋体", Font.BOLD, 30); //通过Font构造字体

    g.setColor(getRandColor(200, 250)); //改变图形的当前颜色为随机生成的颜色

    g.fillRect(0, 0, width , height); //绘制一个填色矩形

    (3)绘制一条干扰线(折线),颜色为深灰色,位置随机产生,具体代码如下:

    //创建一个供画笔选择线条粗细的对象

    BasicStroke bs=new BasicStroke(2f,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL);

    g2d.setStroke(bs); //改变线条的粗细

    g.setColor(Color.DARK_GRAY); //设置当前颜色为预定义颜色中的深灰色

    int[] xPoints=new int[3];

    int[] yPoints=new int[3];

    for(int j=0;j<3;j++){

    xPoints[j]=random.nextInt(width - 1);

    yPoints[j]=random.nextInt(height - 1);

    }

    g.drawPolyline(xPoints, yPoints,3); //绘制折线

    (4)随机生成4个英文和数字混合的验证码文字,并对文件进行随机缩放并旋转,具体代码如下:

    //生成并输出随机的验证文字

    g.setFont(mFont);

    String sRand="";

    int itmp=0;

    for(int i=0;i<4;i++){

    if(random.nextInt(2)==1){

    itmp=random.nextInt(26)+65; //生成A~Z的字母

    }else{

    itmp=random.nextInt(10)+48; //生成0~9的数字

    }

    char ctmp=(char)itmp;

    sRand+=String.valueOf(ctmp);

    Color color=new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110));

    g.setColor(color);

    /****随机缩放文字并将文字旋转指定角度**/

    //将文字旋转指定角度

    Graphics2D g2d_word=(Graphics2D)g;

    AffineTransform trans=new AffineTransform();

    trans.rotate(random.nextInt(45)*3.14/180,15*i+10,7);

    //缩放文字

    float scaleSize=random.nextFloat()+0.8f;

    if(scaleSize>1.1f) scaleSize=1f;

    trans.scale(scaleSize, scaleSize);

    g2d_word.setTransform(trans);

    /************************/

    g.drawString(String.valueOf(ctmp),30*i+40,16); //输出生成的文字

    }

    (5)将生成的验证码保存到Session中,并输出生成后的验证码图片,具体代码如下:

    //将生成的验证码保存到Session中

    HttpSession session=request.getSession(true);

    session.setAttribute("randCheckCode",sRand);

    g.dispose();

    ImageIO.write(image,"JPEG",response.getOutputStream());

     

    希望看了对大家有帮助!

  • 相关阅读:
    webpack前端构建工具学习总结(一)之webpack安装、创建项目
    当执行 import vue from 'vue' 时发生了什么?
    WEBSTORM新建VUE类型文件设置
    基于vue-cli搭建HelloWorld项目
    vue-cli脚手架安装
    浏览器的重绘和回流
    strcpy和strncpy用法和区别
    &与&&有什么区别?
    状态机实践入门
    12864点阵液晶显示模块的原理和实例程序(HJ12864M-1)
  • 原文地址:https://www.cnblogs.com/zkn11199/p/5558120.html
Copyright © 2011-2022 走看看