验证码之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.对于SimpleCaptchaFilter中doGet()方法中为什么有那么多注释了的方法,是因为方便以后我更好的改动我的代码,如果我现在想要另外一种效果,只需要将某些注释去掉和注释掉现有部分代码。
2.对于使用的比较多的功能我就将它们放到前端进行可配。比如:text,以及noise.如果需要改效果就改一下源代码好了。
验证码之SimpleCaptcha (一)
http://www.iteye.com/topic/790024#1719204
原文:https://www.iteye.com/topic/790038
验证码之SimpleCaptcha (二)的更多相关文章
- 验证码之SimpleCaptcha (一)
在captcha中,两个比较著名的框架验证码有Jcaptcha和simpleCaptcha,Jcaptcha太庞大了,所以我选择了简单的SimpleCaptcha simpleCaptch ...
- 【腾讯Bugly干货分享】腾讯验证码的十二年
本文来自于腾讯bugly开发者社区,未经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/581301b146dfb1456904df8d Dev Club 是一个交流移动 ...
- 【Dev Club 分享】腾讯验证码的十二年
源:http://mp.weixin.qq.com/s?__biz=MzA3NTYzODYzMg==&mid=2653578147&idx=3&sn=94a8f8f8b4a23 ...
- Spring Cloud OAuth2(二) 扩展登陆方式:账户密码登陆、 手机验证码登陆、 二维码扫码登陆
概要 基于上文讲解的spring cloud 授权服务的搭建,本文扩展了spring security 的登陆方式,增加手机验证码登陆.二维码登陆. 主要实现方式为使用自定义filter. Authe ...
- Servlet实现数字字母验证码图片(二)
Servlet实现数字字母验证码图片(二): 生成验证码图片主要用到了一个BufferedImage类,如下:
- Python 图形验证码库、二维码库的使用
1. 图形验证码库 captcha # 引入图形库 from captcha.image import ImageCaptcha # 获取图像对象 image = ImageCaptcha(width ...
- PHP中的验证码类(验证码功能设计之二)
运行结果: <!--vcode.class.php内容--> <?php class Vcode { private $width; //宽 private $height; //高 ...
- grails2.3.11第二课
第二课主要介绍grails相关插件的使用,这是敏捷开发所必需的途径. 可以把grails的插件看作是grails正常项目的迷你型,因为看插件的源码,它的目录结构和正常项目相差无几. 官方开源插件地址 ...
- WPF中实现验证码功能
其实和winform中的实现差不多,只是由于WPF中控件使用的库与winform中的有区别,大体上还是差不多的,直接看代码: 产生验证码的类:ValidCode.cs public class Val ...
随机推荐
- opencv学习之路(15)、形态学其他操作(开、闭、顶帽、黑帽、形态学梯度)
一.形态学其他操作(用的不多,如果忘了也可以通过膨胀腐蚀得到相同效果) 1.开运算 2.闭运算 3.形态学梯度 4.顶帽 5.黑帽 #include "opencv2/opencv.hpp& ...
- 20145320《网络对抗》注入Shellcode并执行
20145320注入Shellcode并执行 准备一段Shellcode 首先先准备一段C语言代码:这段代码其实和我们的shell功能基本一样 为了之后能够看到反汇编的结果,这次采用的静态编译.正常返 ...
- 一、虚拟环境.二、路由配置主页与404.三、2.x路由分发.四、伪静态.五、request对象.六、FBV与CBV.七、文件上传.
一.虚拟环境 ''' 解决版本共存 1. 用pycharm选择File点击NewProject然后选择virtualenv创建一个纯净环境 2. 打开下载的目录将venv文件夹下的所有文件(纯净的环境 ...
- CentOS7 搭建Docker
搭建环境 Docker支持一下的CentOS版本 CentOS 6.5 (64-bit)或者更高版本 CentOS 7 (64-bit) 搭建条件 Docker运行在CentOS 7上,要求系统64位 ...
- Vue学习【第二篇】:ES6简单介绍
ECMAScript 6简介 ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了.它的目标,是使得 JavaScript ...
- Docker 入门指南——部署常用服务示例
MongoDB FROM centos:centos7 MAINTAINER The CentOS Project <cloud-ops@centos.org> RUN yum -y up ...
- 12.27 cf div3 解题报告
12.27 cf div3 解题报告 wxy.wxy,带上分拉,全场做了个无脑小白 比赛场地 A: T1,跟着模拟就好了 B: sort一遍之后 去除的数一定是a[1]或者a[n] 比较去除谁小就输出 ...
- 三星固态硬盘ssd产品线收集
目录 三星ssd按时间展示: 三星ssd后缀带a与不带a的区别,举其中一例: 下面是从三星中国的官网截图的产品线: 产品线列表: 总结: 参考: 最近在淘宝看到了很多拆机ssd,三星作为世界上唯一一家 ...
- 【分布式事务】spring cloud集成lcn解决分布式事务
参考地址:https://blog.csdn.net/u010882691/article/details/82256587 参考地址:https://blog.csdn.net/oyh1203/ar ...
- C语言 字符串大小写转换 自定义函数
#include <stdio.h>#include <stdlib.h>#include <string.h> char * strtolower(char * ...