SimpleCaptcha验证码组件使用

标签: simplecaptcha 验证码 | 发表时间:2015-04-19 00:01 | 作者:pyzheng
出处:http://www.iteye.com
http://zhangzhaoaaa.iteye.com/blog/2197359
最近需要做一个验证码信息,在网上找了些验证码组件,选择了SimpleCaptcha组件,java服务器端代码,简单方便使用。
      对于此组件里的中文字的验证码,不是很合适,有时候会出现乱码情况,我认为如果想要加入中文字的验证,自己实现匹配就行了。
     我这里只做抛砖引玉,贴出主要代码,源码包,SimpleCaptcha组件的源码和DOCS供参考使用(全包超过10mb,不让上传啊)。如果只是用数字和英文字母使用验证码,不用考虑自定义的验证码SimpleCaptchaFilter.java。后台代码很容易改成SpringMVC等使用,我就不多说啦,show me the code.
      效果:


     附件:Test.zip是我已实现的源码工程
               docs.zip是组件文档
               examples.zip是组件例子
               Java.zip是组件源码
1.captcha.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding="UTF-8"%>  
    <%  
String path = request.getContextPath();  
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";  
%>  
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>验证码</title>  
<script type="text/javascript" src="<%=basePath %>/js/jquery.js" ></script>  
</head>  
<body>  
 <img id="code" style="cursor:pointer;" alt="看不清楚?点图标可以换一个" title="看不清楚?点图标可以换一个" />    
    <form action="<%=basePath %>/CheckCode" method="post">    
        <input id="answer" name="answer" />    
        <input id="submitBtn" type="button" value="提交" name="submit"/>    
</form>  
<script type="text/javascript">  
    $(function(){  
        var imgCode = $('#code');   
        $(imgCode).attr('src',"<%=basePath %>/simpleImg");  
        $(imgCode).click(function(){  
            $(this).attr('src',"<%=basePath %>/simpleImg");  
        });  
        $('#submitBtn').click(function(){  
            $.post('<%=basePath %>/CheckCode?answer='+$('#answer').val(),function(data){  
                if (data=='true'){  
                    window.location.href="<%=basePath %>/captchaSuccess.jsp";  
                }else{  
                    alert("验证码错误!");      
                    return false;  
                }  
            });  
        });  
    });  
</script>  
</body>  
</html>
 

2.captchaSuccess.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding="UTF-8"%>  
  
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>验证码</title>  
</head>  
<body>  
你成功了!  
</body>  
</html> 


3.CheckCode.java
import java.io.IOException;  
import java.io.PrintWriter;  
  
import javax.servlet.ServletException;  
import javax.servlet.http.HttpServlet;  
import javax.servlet.http.HttpServletRequest;  
import javax.servlet.http.HttpServletResponse;  
  
import nl.captcha.Captcha;  
  
/** 
 * Servlet implementation class CheckCode 
 */  
public class CheckCode extends HttpServlet {  
    private static final long serialVersionUID = 1L;  
         
    /** 
     * @see HttpServlet#HttpServlet() 
     */  
    public CheckCode() {  
        super();  
        // TODO Auto-generated constructor stub  
    }  
  
    /** 
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 
     */  
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  
        this.doPost(request, response);  
    }  
  
    /** 
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 
     */  
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  
        Captcha captcha = (Captcha) request.getSession().getAttribute(Captcha.NAME);    
        request.setCharacterEncoding("UTF-8");    
        String answer = request.getParameter("answer");  
        System.out.println(captcha.isCorrect(answer));  
        PrintWriter writer = response.getWriter();  
        writer.print(captcha.isCorrect(answer));  
        writer.flush();  
        writer.close();  
    }  
  
} 


4.SimpleCaptchaFilter.java
import static nl.captcha.Captcha.NAME;  
  
import java.awt.Color;  
import java.awt.Font;  
import java.awt.image.BufferedImage;  
import java.io.FileInputStream;  
import java.io.IOException;  
import java.util.ArrayList;  
import java.util.List;  
  
import javax.imageio.ImageIO;  
import javax.servlet.ServletException;  
import javax.servlet.http.HttpServlet;  
import javax.servlet.http.HttpServletRequest;  
import javax.servlet.http.HttpServletResponse;  
  
import nl.captcha.Captcha;  
import nl.captcha.Captcha.Builder;  
import nl.captcha.backgrounds.FlatColorBackgroundProducer;  
import nl.captcha.gimpy.BlockGimpyRenderer;  
import nl.captcha.servlet.CaptchaServletUtil;  
import nl.captcha.text.producer.ChineseTextProducer;  
import nl.captcha.text.producer.DefaultTextProducer;  
import nl.captcha.text.renderer.ColoredEdgesWordRenderer;  
import nl.captcha.text.renderer.WordRenderer;  
  
/** 
 * @className:SimpleCaptchaFilter.java 
 * @classDescription: 扩展默认的simpleCaptcha 
 * @author:zz 
 * @createTime:2015-3-30 
 */  
  
public class SimpleCaptchaFilter extends HttpServlet{  
       
      private static final String PARAM_HEIGHT = "height"; //高度 默认为50  
    
      private static final String PARAM_WIDTH = "width";//宽度 默认为200  
        
      private static final String PAEAM_NOISE="noise";//干扰线条 默认是没有干扰线条  
        
      private static final String PAEAM_TEXT="text";//文本  
  
      protected int _width = 200;  
      protected int _height = 50;  
      protected boolean _noise=false;  
      protected String _text=null;  
        
      /** 
       * 初始化过滤器.将配置文件的参数文件赋值 
       * @throws ServletException 
       */  
      @Override  
        public void init() throws ServletException {  
            if (getInitParameter(PARAM_HEIGHT) != null) {  
                _height = Integer.valueOf(getInitParameter(PARAM_HEIGHT));  
            }  
              
            if (getInitParameter(PARAM_WIDTH) != null) {  
                _width = Integer.valueOf(getInitParameter(PARAM_WIDTH));  
            }  
              
            if (getInitParameter(PAEAM_NOISE) != null) {  
                _noise = Boolean.valueOf(getInitParameter(PAEAM_NOISE));  
            }  
              
            if (getInitParameter(PAEAM_NOISE) != null) {  
                _text = String.valueOf(getInitParameter(PAEAM_TEXT));  
            }  
        }  
        
      /** 
       * 因为获取图片只会有get方法 
       */  
       @Override  
      public void doGet(HttpServletRequest req, HttpServletResponse resp)  
            throws ServletException, IOException {  
             
           Builder builder=new Captcha.Builder(_width, _height);  
           //增加边框  
           builder.addBorder();  
             
           //干扰线  
           /*CurvedLineNoiseProducer nosi = new CurvedLineNoiseProducer(Color.green,5); 
           builder.addNoise(nosi);*/  
           //是否增加干扰线条  
           if(_noise==true)  
               builder.addNoise();  
           //----------------自定义字体大小-----------  
           //自定义设置字体颜色和大小 最简单的效果 多种字体随机显示  
           List<Font> fontList = new ArrayList<Font>();  
           fontList.add(new Font("Arial", Font.ITALIC, 40));//可以设置斜体之类的  
           //fontList.add(new Font("Courier", Font.BOLD, 40));    
           /*List<Color> colorList = new ArrayList<Color>(); 
           colorList.add(Color.green); 
           colorList.add(Color.BLUE); 
           DefaultWordRenderer dwr=new DefaultWordRenderer(colorList,fontList);*/  
             
           //加入多种颜色后会随机显示 字体空心  
           List<Color> colorList=new ArrayList<Color>();  
           colorList.add(Color.green);  
          // colorList.add(Color.white);  
           colorList.add(Color.blue);  
           ColoredEdgesWordRenderer cwr= new ColoredEdgesWordRenderer(colorList,fontList);  
             
           WordRenderer wr=cwr;  
           //增加文本,默认为5个随机字符.  
           if(_text==null){  
               builder.addText();  
           }else{  
               String[]ts=_text.split(",");  
               for(int i=0;i<ts.length;i++){  
                   String[] ts1=ts[i].split(":");  
                   if("chinese".equals(ts1[0])){  
                      builder.addText(new ChineseTextProducer(Integer.parseInt(ts1[1])),wr);  
                   }else if("number".equals(ts1[0])){  
                       //这里没有0和1是为了避免歧义 和字母I和O  
                       char[] numberChar = new char[] { '2', '3', '4', '5', '6', '7', '8' };  
                       builder.addText(new DefaultTextProducer(Integer.parseInt(ts1[1]),numberChar),wr);  
                   }else if("word".equals(ts1[0])){  
                       //原理同上  
                       char[] numberChar = new char[] {'a','A', 'b', 'B','c','C', 'd','D',  
                                'e','E', 'f', 'F','g','G', 'h','H', 'k','K', 'm','M', 'n','N', 'p','P', 'r','R', 'w','W', 'x','X', 'y','Y' };  
                       builder.addText(new DefaultTextProducer(Integer.parseInt(ts1[1]),numberChar),wr);  
                   }/*else{ 
                       builder.addText(new DefaultTextProducer(Integer.parseInt(ts1[1])),wr); 
                   }*/  
               }  
                 
           }  
             
         //--------------添加背景-------------  
           //设置背景渐进效果 以及颜色 form为开始颜色,to为结束颜色  
           //GradiatedBackgroundProducer gbp=new GradiatedBackgroundProducer();  
           //gbp.setFromColor(Color.yellow);  
          // gbp.setToColor(Color.red);  
           //无渐进效果,只是填充背景颜色  
//         FlatColorBackgroundProducer  fbp=new FlatColorBackgroundProducer(Color.red);  
           //加入网纹--一般不会用  
//         SquigglesBackgroundProducer  sbp=new SquigglesBackgroundProducer();  
           // 没发现有什么用,可能就是默认的  
//         TransparentBackgroundProducer tbp = new TransparentBackgroundProducer();  
           //FlatColorBackgroundProducer fbp = new FlatColorBackgroundProducer();  
           //BufferedImage bufferedImage = ImageIO.read(new FileInputStream("E:\\eclipsespace2\\oms_portal\\WebContent\\images\\content\\table-info.png"));  
           //fbp.addBackground(bufferedImage);  
             
           //builder.addBackground(fbp);  
           //---------装饰字体---------------  
           // 字体边框齿轮效果 默认是3  
           builder.gimp(new BlockGimpyRenderer(1));  
           //波纹渲染 相当于加粗  
//         builder.gimp(new RippleGimpyRenderer());  
           //修剪--一般不会用  
//         builder.gimp(new ShearGimpyRenderer(Color.red));  
           //加网--第一个参数是横线颜色,第二个参数是竖线颜色  
//         builder.gimp(new FishEyeGimpyRenderer(Color.red,Color.yellow));  
           //加入阴影效果 默认3,75   
//         builder.gimp(new DropShadowGimpyRenderer());  
           //创建对象  
          Captcha captcha =  builder .build();  
             
       CaptchaServletUtil.writeImage(resp, captcha.getImage());  
       req.getSession().setAttribute(NAME, captcha);  
    }  
} 


5.web.xml
<?xml version="1.0" encoding="UTF-8"?>  
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
    xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
    id="WebApp_ID" version="2.5">  
    <display-name>Test</display-name>  
    <!-- 默认简单的验证码处理 -->  
    <servlet>  
        <servlet-name>SimpleCaptcha</servlet-name>  
        <servlet-class>nl.captcha.servlet.SimpleCaptchaServlet</servlet-class>  
        <init-param>  
            <param-name>width</param-name>  
            <param-value>250</param-value>  
        </init-param>  
        <init-param>  
            <param-name>height</param-name>  
            <param-value>75</param-value>  
        </init-param>  
    </servlet>  
    <servlet-mapping>  
        <servlet-name>SimpleCaptcha</servlet-name>  
        <url-pattern>/simpleImg</url-pattern>  
    </servlet-mapping>  
    <!-- 自定义验证码 -->  
    <!-- <servlet> <servlet-name>SimpleCaptcha</servlet-name> <servlet-class>SimpleCaptchaFilter</servlet-class>   
        <init-param> <param-name>width</param-name> <param-value>200</param-value>   
        </init-param> <init-param> <param-name>height</param-name> <param-value>50</param-value>   
        </init-param> 干扰线 <init-param> <param-name>noise</param-name> <param-value>true</param-value>   
        </init-param> 意思是3个单词,3个数字 <init-param> <param-name>text</param-name> <param-value>word:3,number:3</param-value>   
        </init-param> </servlet> <servlet-mapping> <servlet-name>SimpleCaptcha</servlet-name>   
        <url-pattern>/simpleImg</url-pattern> </servlet-mapping> -->  
    <!-- 验证码检验 -->      
    <servlet>  
        <description></description>  
        <display-name>CheckCode</display-name>  
        <servlet-name>CheckCode</servlet-name>  
        <servlet-class>CheckCode</servlet-class>  
    </servlet>  
    <servlet-mapping>  
        <servlet-name>CheckCode</servlet-name>  
        <url-pattern>/CheckCode</url-pattern>  
    </servlet-mapping>  
</web-app>
 

   参考:
http://www.iteye.com/topic/790024
http://www.iteye.com/topic/790038

已有 0 人发表留言,猛击->> 这里<<-参与讨论


ITeye推荐



相关 [simplecaptcha 验证码] 推荐:

SimpleCaptcha验证码组件使用

- - 企业架构 - ITeye博客
最近需要做一个验证码信息,在网上找了些验证码组件,选择了SimpleCaptcha组件,java服务器端代码,简单方便使用.       对于此组件里的中文字的验证码,不是很合适,有时候会出现乱码情况,我认为如果想要加入中文字的验证,自己实现匹配就行了.      我这里只做抛砖引玉,贴出主要代码,源码包,SimpleCaptcha组件的源码和DOCS供参考使用(全包超过10mb,不让上传啊).

java 验证码

- - ITeye博客
// 创建字体,字体的大小应该根据图片的高度来定. // 随机产生160条干扰线,使图象中的认证码不易被其它程序探测到. // randomCode用于保存随机产生的验证码,以便用户登录后进行验证. // 随机产生codeCount数字的验证码. // 得到随机产生的验证码数字. // 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同.

验证码新趋势:NuCaptcha推出动态验证码

- Mac.Baby - 36氪
曾开发过提供视频验证码服务的加拿大创业公司NuCaptcha刚刚发布了动态验证码,可为网站提供新的安全保证,有望为验证码市场带来新气象. 验证码是人们在网站上最常见的安全问题,只要是上网的人都会遇到被要求辨认和输入数字或者单词的情况. 网站通过验证码来区分人和恶意程序. 而我们所见的大部分的验证码都是基于文字的.

10种用户友好的验证码

- Liang - cnBeta.COM
众所周知,验证码就是帮助我们确定答案不是由电脑自己生成的. 今天我推荐给大家10种用户体验绝佳、令人意想不到的验证码设计风格.

使用 PIL 生成验证码图片

- HarryHan - python.cn(jobs, news)
现在的网页中,为了防止机器人提交表单,图片验证码是很常见的应对手段之一. 这里就不详细介绍了,相信大家都遇到过. 现在就给出用Python的PIL库实现验证码图片的代码. _letter_cases = "abcdefghjkmnpqrstuvwxy" # 小写字母,去除可能干扰的i,l,o,z. _upper_cases = _letter_cases.upper() # 大写字母.

response生成图片验证码

- - ITeye博客
服务器对客户端浏览器做出的响应被封装成一个HttpResponse对象. 要对浏览器进行操作,只需要操作HttpRespones对象,通过HttpServletResponse.getWriter()获得PrintWriter,该对象为outputStream的子类.     本例将使用Servlet输出图片验证码.

验证码的现在与未来

- Yishen - 爱范儿 · Beats of Bits
”验证码“( CAPTCHA )其实并不是各位网友总是在不同网站上看到的难以辨认的字母组合的代名词,而是“全自动区分计算机和人类的图灵测试”的俗称,顾名思义,它的作用是区分计算机和人类. 在 CAPTCHA 测试中,作为服务器的计算机会自动生成一个问题由用户来解答. 这个问题可以由计算机生成并评判,但是必须只有人类才能解答.

jsp+servlet实现验证码功能

- - CSDN博客推荐文章
验证码的功能大多数人可能不都理解,但几乎每个安全网站都会有. 验证码是用来防止非人为因素操作的行为,例如一个黑客要黑一个网站,怎么弄呢. 最简单的思路当然是造成其网路拥堵直至系统瘫痪掉. 如果没有验证码,那么我就可以在注册页面,写一个程序,只有注册表单,不断更换主键或不可重复的内容,不停的提交. 那这样每秒可以注册几万次都有可能,这样服务器就大量负载,很容易就瘫痪并死掉.

Servlet实现图形验证码

- - CSDN博客推荐文章
|-- 配置开发图形验证码Servlet. // 设置响应头 Content-type类型. // 以下三句是用于设置页面不缓存. // 建立指定宽、高和BufferedImage对象. Graphics g = image.getGraphics(); // 该画笔画在image上. Color c = g.getColor(); // 保存当前画笔的颜色,用完画笔后要回复现场.

TensorFlow自动识别验证码(二)

- -
在 使用tensorflow自动识别验证码(一) 这篇文章中,对使用tensorflow自动识别验证码的过程做了简单的了解和编写. 那么今天这篇文章将对上篇文章中代码进行修改用于实现对主流的CMS进行验证码的破解. 先回顾一下 tensorflow 的自动识别验证码的步骤. 由于后面三步基本都是tensorflow自动完成.