验证码

这份源代码是从网上下载下来的开源项目captcha,是用来生成验证码的。因项目需要,需要对原来的验证码改造,且原来的验证码很可能被破解,估采用这个项目。,

下载下来的代码在linux的环境不能正常显示验证码图片,这份代码是经过修改而来的。并且增加了一些可配置的参数。
参数以配置文件的形式存放。
使用方法:

private static Properties prop = new Properties();
CaptchaProducer p = new DefaultCaptchaIml(prop);

static{
try{
prop.load(ClassLoader.getSystemResourceAsStream("option.properties"));
}catch(IOException ioe) {
System.err.println("cant find verify code component config file for captcha.");
System.err.println(ioe);
}
}


public static void createImage(java.io.OutputStream out, String capText) throws IOException {
p.createImage(out, capText);
}

public static void main(String[] args) {
System.setProperty("java.awt.headless", "true");
String validCode = genString ( 4 );

BufferedImage image = genImage(validCode);

try {
FileOutputStream imageFile = new FileOutputStream("./"+System.currentTimeMillis()+"-1.jpg");
createImage(imageFile, validCode);
} catch ( Exception e ) {
System.out.println ( e );
}
}

配置文件说明:
配置文件详见aindcommon/web-inf/verifycode.properties,
如要修改,请修改这个文件。


cap.border=yes
生成的图片是否有边线;如yes: , no:
cap.border.c=black
边线的颜色;
cap.border.th=1
边线的粗度,只对设置了边线才有效;

cap.obscurificator=nl.captcha.obscurity.imp. WaterRiple
图片效果的设置:
可以设置的选择有:
nl.captcha.obscurity.imp.ShadowGimpyImp 生成的字体有阴影
nl.captcha.obscurity.imp.WaterRiple 无阴影。
nl.captcha.obscurity.imp.FishEyeGimpyImp 鱼网底的形式。

cap.cap.producer=nl.captcha.servlet.DefaultCaptchaIml
生成验证码图片的默认实现,就是这个。这里是一个servlet,可以部署成servlet,

cap.word.imp=nl.captcha.text.imp.DefaultWordRenderer
字体的效果,只有这个默认的实现,不需要修改;
cap.text.producer=nl.captcha.text.imp.FiveLetterFirstNameTextCreator
生成字符的方案,目前我们没有使用,使用的是我们自己的生成的字符。若需要设置:
可选择:nl.captcha.text.imp. DefaultTextCreator

cap.char.arr=2,3,4,6,7,8,a,b,c,d,e,f,g,h,k,o,r,s,t,x,y
针对nl.captcha.text.imp. DefaultTextCreator 这种字符生成方案允许的字符;字符间以逗号分隔开。

cap.char.arr.l=6
针对nl.captcha.text.imp. DefaultTextCreator 这种字符生成方案 生成验证码的长度;这里是6个字符。可修改
cap.font.arr= Arial,Helvetica,Courier,TimesRoman
验证码字符的字体,各种字体以逗号隔开,可设置多个。
cap.font.size=25
验证码字符的字体大小;
cap.font.color=30,23,29
验证码字符的字体的颜色;
cap.bg.imp=nl.captcha.obscurity.imp.DefaultBackgroundImp
验证码图片的背景颜色实现方式。目前只有这种方式的实现,不需要修改。
cap.background.c.to=255,255,255
背景颜色的渐变范围,这里是to,最多只能变到白色的底。
cap.background.c.from=75,75,255
背景颜色的渐变范围,这里是from,由这个颜色开始变化。如 上面 的图中显示的开始是蓝色后面是快成白色的样子。
cap.noise.imp=nl.captcha.obscurity.imp.DefaultNoiseImp
图片的混淆效果,就是中间的线。目前只有这种实现,不需要修改。
cap.noise.c=30,23,29
图片的混淆效果,就是中间的线的颜色。可以设置来改变,但是最好和验证码字符的颜色一致,达到不易辨认的效果。如:red
image.width=100
验证码图片的宽度。
image.height=36
验证码图片的高度。


注:目前在我们的系统中,生成字符不是由验证码这个组件来完成的。所以对于以上生成字符的配置可以不做修改。对应以上红色的部分配置。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值