利用Servlet生成动态验证码

先创建一个Servlet

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

/**
 * Created by Song on 2015/4/18.
 */
public class ValidateServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //禁止页面缓存
        response.setHeader("Prama","No-cache");
        response.setHeader("Cache-Control", "No-cache");
        response.setDateHeader("Expires", 0);
        response.setContentType("image/jpeg");  //设置相应正文的MIME类型图片
        int width = 60, height = 20;
        /*
        创建一个位于缓冲区的图像,宽度60,高度20
         */
        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        Graphics g = image.getGraphics();
        Random random = new Random();
        g.setColor(getRandomColor(200, 250));
        g.fillRect(0, 0, width, height);
        g.setFont(new Font("Times New Roman", Font.PLAIN, 18)); // 字体格式
        g.setColor(getRandomColor(160,200));
        for (int i=0; i<130; i++){
            int x=random.nextInt(width);
            int y=random.nextInt(height);
            int x1=random.nextInt(12);
            int y1=random.nextInt(12);
            g.drawLine(x,y,x+x1,y+y1);  //在图像的坐标(x,y)和坐标(x+x1, y+y1)之间画干扰线
        }
        String strCode="";
        for (int i=0; i<=4; i++){
            String strNumber = String.valueOf(random.nextInt(10));
            strCode += strNumber;
            //设置字体颜色
            g.setColor(new Color(15+random.nextInt(120), 15+random.nextInt(120), 15+random.nextInt(120)));
            g.drawString(strNumber, 13*i+6, 16);
        }
        request.getSession().setAttribute("Code",strCode);  //把验证码保存到session中
        g.dispose();                                        //释放图像的上下文以及使用的所有系统资源
        ImageIO.write(image,"JPEG",response.getOutputStream()); //输出JPEG格式的图像
        response.getOutputStream().flush();                      //刷新输出流
        response.getOutputStream().close();                      //关闭输出流
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    public Color getRandomColor(int fc, int bc){
        Random random = new Random();
        Color randomColor = null;
        if(fc>255)
            fc = 255;
        if(bc>255)
            bc = 255;

        //设置0~255之间的随机颜色值
        int r = fc + random.nextInt(bc - fc);
        int g = fc + random.nextInt(bc - fc);
        int b = fc + random.nextInt(bc - fc);

        randomColor = new Color(r,g,b);
        return randomColor;
    }
}

在XML文件中配置:

    <servlet-mapping>
        <servlet-name>ValidateServlet</servlet-name>
        <url-pattern>/validatecode</url-pattern>
    </servlet-mapping>

  然后在index.jsp中调用

 <form action="" method="post">
    <table align="center">
      <tr>
        <td>用户名:</td><td><input type="text" name="name"/> </td>
      </tr>
      <tr>
        <td>验证码:</td><td><img  src="validatecode"/> </td>
      </tr>
      <tr>
        <td>输入验证码: </td> <td><input type="text" name="code"/></td>
      </tr>
    </table>
  </form>
时间: 2024-10-03 03:48:16

利用Servlet生成动态验证码的相关文章

servlet生成数字验证码

servlet生成一个数字验证码 1.设置背景 private void setBackGround(Graphics g) { g.setColor(Color.orange); g.fillRect(0, 0, WIDTH, HEIGHT); } 2.得到图片框 private void setBorder(Graphics g) { g.setColor(Color.black); g.drawRect(1, 1, WIDTH - 2, HEIGHT - 2); } 3.画干扰线 priv

php生成动态验证码

<?php /** *ImageCode 生成包含验证码的GIF图片的函数 *@param $string 字符串 *@param $width 宽度 *@param $height 高度 **/ function ImageCode($string='',$width=75,$height=25){ $authstr=$string?$string:((time()%2==0)?mt_rand(1000,9999):mt_rand(10000,99999)); $board_width=$wi

PHP利用jquery生成各种验证码和Ajax验证

PHP生成验证码图片 PHP生成验证码的原理:使用PHP的GD库,生成一张带验证码的图片,并将验证码保存在Session中.PHP 生成验证码的大致流程有: 1.产生一张png的图片: 2.为图片设置背景色: 3.设置字体颜色和样式: 4.产生4位数的随机的验证码: 5.把产生的每个字符调整旋转角度和位置画到png图片上: 6.加入噪点和干扰线防止注册机器分析原图片来恶意破解验证码: 7.输出图片: 8.释放图片所占内存. 下面我们讲解验证码的生成过程,直接上代码. session_start(

利用 PIL模块实现生成动态验证码

简单说下需求: 当用户点击动态框时,实现实时更换动态库里的数字更换 模块: PIL  io 前端页面: <img src="/get_code/" id="id_img" width="260" height="35"> <script> $('#id_img').click(function () { let old_path = $('#id_img').attr('src'); $(this).a

利用Django生成动态图片验证码

首先,制作随机验证码需要引入随机模块,即random模块,并写出随机颜色函数,具体如下: import random def get_random_color(): return (random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)) 之后我们引入Python的常用制图模块Pillow,pip install pillow一下,有些情况下某些模块下载后依然无法直接在项目中使用,此时我们需要前往setting

生成动态验证码

php代码 <?php header('Content-Type:image/png');//设置content-type为png图片 header('Cache-Control:no-cache');//设置为不能缓存 //设置验证码的宽高 $w = 120; $h = 40; //要在服务器内存中创建一个图片 $img = imagecreate($w,$h); //为图片分配一个背景颜色,RGB(255,255,255) //2,3,4参数代表RGB,之所以分配180和240,是为了生成一

Servlet动态验证码的生成-带数字和字母

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 一.实现的思路: (1)首先,需要创建一个Servlet.该Servlet通过字节型响应给客户端返回一个图片,该图片是通过JDK中Java 2D的类库来生成一个图片.图片的生成是依靠一个随机数来完成,然后将这个随机数写成图片格式.最后在Session将这个随机的字符串的状态保持住,以便在用户填写后进行对比. (2)其次,在需要加入验证码的JSP页面中,通过<img src="生成验证码

Servlet仿CSDN动态验证码的生成-带数字和字母

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 一.实现的思路: (1)首先,须要创建一个Servlet.该Servlet通过字节型响应给client返回一个图片.该图片是通过JDK中Java 2D的类库来生成一个图片. 图片的生成是依靠一个随机数来完毕,然后将这个随机数写成图片格式.最后在Session将这个随机的字符串的状态保持住,以便在用户填写后进行对照. (2)其次,在须要加入验证码的JSP页面中,通过<img src="生

iOS 生成本地验证码

在应用程序注册.登陆或者有关支付确认的界面,经常会用到验证码,验证码有的是通过手机发送获取的,有的是在本地点击获取的,通过手机发送获取的动态验证码可以使用第三方类库实现,本地点击获取的是在本地自己绘制的,下面我们来详细讲解一下本地生成动态验证码的过程. 导入CoreGraphics.framework 验证码封装了一个UIView,在使用的时候直接把这个View加到界面上使用 CaptchaView.h #import <UIKit/UIKit.h> @interface CaptchaVie