验证码之SimpleCaptcha (二)

上回说到了简单的使用simpleCaptcha,这次我们这次我们将讲解扩张simpleCaptcha。
回到正题,我们需要一些自定义的验证码,比如验证码的字体大小,背景,颜色等等,默认的验证码是无法满足我们的需求的。所以我们得自己去实现。我这几提供了简单的扩展,如果大家有什么好的建议大家一起来探讨。
自定义过滤器:SimpleCaptchaFilter
package com.xyj.com.tool.captcha;

import static nl.captcha.Captcha.NAME;


import java.awt.Color;
import java.awt.Font;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import nl.captcha.Captcha;
import nl.captcha.Captcha.Builder;
import nl.captcha.backgrounds.BackgroundProducer;
import nl.captcha.backgrounds.FlatColorBackgroundProducer;
import nl.captcha.backgrounds.GradiatedBackgroundProducer;
import nl.captcha.backgrounds.SquigglesBackgroundProducer;
import nl.captcha.backgrounds.TransparentBackgroundProducer;
import nl.captcha.gimpy.BlockGimpyRenderer;
import nl.captcha.gimpy.DropShadowGimpyRenderer;
import nl.captcha.gimpy.FishEyeGimpyRenderer;
import nl.captcha.gimpy.RippleGimpyRenderer;
import nl.captcha.gimpy.ShearGimpyRenderer;
import nl.captcha.servlet.CaptchaServletUtil;
import nl.captcha.servlet.SimpleCaptchaServlet;
import nl.captcha.text.producer.ChineseTextProducer;
import nl.captcha.text.producer.DefaultTextProducer;
import nl.captcha.text.renderer.ColoredEdgesWordRenderer;
import nl.captcha.text.renderer.DefaultWordRenderer;
import nl.captcha.text.renderer.WordRenderer;

/**
* @className:SimpleCaptchaFilter.java
* @classDescription: 扩展默认的simpleCaptcha
* @author:xiayingjie
* @createTime:2010-10-20
*/

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();
//是否增加干扰线条
if(_noise==true)
builder.addNoise();
//----------------自定义字体大小-----------
//自定义设置字体颜色和大小 最简单的效果 多种字体随机显示
List<Font> fontList = new ArrayList<Font>();
// fontList.add(new Font("Arial", Font.HANGING_BASELINE, 40));//可以设置斜体之类的
fontList.add(new Font("Courier", Font.BOLD, 40));
DefaultWordRenderer dwr=new DefaultWordRenderer(Color.green,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=dwr;
//增加文本,默认为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', 'b', 'c', 'd',
'e', 'f', 'g', 'h', 'k', 'm', 'n', 'p', 'r', 'w', 'x', '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();


builder.addBackground(gbp);
//---------装饰字体---------------
// 字体边框齿轮效果 默认是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);
}
}


代码可能稍微有点长,代码里面基本上都写了注释。所以这里就不再重复描述功能了
2.web.wml需要将过滤器改成以上过滤器。
  <servlet>
<servlet-name>StickyCaptcha</servlet-name>
<servlet-class>com.xyj.com.tool.captcha.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>false</param-value>
</init-param>
<!-- 意思是3个单词,3个数字 -->
<init-param>
<param-name>text</param-name>
<param-value>word:3,number:3</param-value>
</init-param>
</servlet>


说明:
1.对于[b]SimpleCaptchaFilter[/b]中[b]doGet()[/b]方法中为什么有那么多注释了的方法,是因为方便以后我更好的改动我的代码,如果我现在想要另外一种效果,只需要将某些注释去掉和注释掉现有部分代码。
2.对于使用的比较多的功能我就将它们放到前端进行可配。比如:text,以及noise.如果需要改效果就改一下源代码好了。


验证码之SimpleCaptcha (一)
[url]http://www.iteye.com/topic/790024#1719204[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值