C#实现的简单验证码识别实例

最近做一个小玩意需要识别验证码,之前从来没有接触过识别验证码这块,这可难倒了我。所以,在网上搜索如何识别验证码,许多前辈写的博文教会了我。怕以后又忘记了,故此写篇随笔记录。
效果可以看下具体51搜索展示http://www.51bt.cc,结合Xunsearch全文检索技术,可以达到毫秒级的数据搜索

我要识别的验证码是一种非常简单,如图:




识别步骤:


1、图片灰度化(把彩色的验证码图片转换成灰色的图片)、图片二值化




复制代码 代码如下:
for (int i = 0; i < bmp.Width; i++)
            {
                for (int j = 0; j < bmp.Height; j++)        //双重循环,遍历验证码图片的像素点
                {
                    Color color = bmp.GetPixel(i, j);        //取位图某点颜色
                    int gray = (int)(color.R * 0.3 + color.G * 0.59 + color.B * 0.11);    //灰度化
                    if (gray * 0.2125 + gray * 0.7154 + gray * 0.0721 >= v)      //二值化,v为阈值,大于等于阈值的设为白色,否者设为黑色
                    {
                        bmp.SetPixel(i, j, Color.FromArgb(255, 255, 255));
                    }
                    else
                    {
                        bmp.SetPixel(i, j, Color.FromArgb(0, 0, 0));
                    }
                }
            }




经过图片灰度化的处理,图片就成这样子:


经过图片二值化的处理,图片就成这样子:


2、图片分割(把四个数字分割出来,保存像素点代码)


把原来的整个验证码图片按照固定的宽、高分割出来(我是按左边距6像素,顶边距4像素,间隔4像素,宽9像素,高12像素分割)。然后取出各个数字图片的像素色,255输出1,其他输出0。就得到108(9*12)个0,1了。




复制代码 代码如下:
111111111111111000000111100000000001001111111100011111111110001111111100100000000001111000000111111111111111


保存完所有数字(0-9)的0,1代码之后,以后就直接与这9串0,1模糊匹配(有杂色的可能,所以要模糊匹配),然后就实现了自动识别验证码。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值