这份源代码是从网上下载下来的开源项目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
验证码图片的高度。
注:目前在我们的系统中,生成字符不是由验证码这个组件来完成的。所以对于以上生成字符的配置可以不做修改。对应以上红色的部分配置。
下载下来的代码在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
验证码图片的高度。
注:目前在我们的系统中,生成字符不是由验证码这个组件来完成的。所以对于以上生成字符的配置可以不做修改。对应以上红色的部分配置。