用 aforge.net 小试一下验证码识别

2023-10-29 02:30

本文主要是介绍用 aforge.net 小试一下验证码识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天来小玩一下 aforge.net 套用官方的话就是一个专门为开发者和研究者基于C#框架设计的,这个框架提供了不同的类库和关于类库的资源,还有很多应用程序例子,包括计算机视觉与人工智能,图像处理,神经网络,遗传算法,机器学习,机器人等领域,下载网址:http://www.aforgenet.com/framework/downloads.html

对了,不知道有多少公司是用得仕卡作为员工的福利卡,我们公司就是这样的,每个月公司都会充值一些money????????????。

上去看了后,哟呵~ 还有个90年代的验证码,我想这年头估计找到这样验证码的网站已经不多了,如果懂一点图像处理都话,这张验证码跟没有一个样,这篇我们看看怎么去识别它。

一:验证码处理

1. 一般处理原则

这种验证码为什么说跟没有一样,第一点:字体规范工整,第二点:不旋转扭曲粘连,第三点:字体颜色单一,这里要注意的是, aforge 只接受像素格式为 24/32bpp 格式图片,所以处理前,先进行格式转化。

//转化图片像素格式var bnew = new Bitmap(b.Width, b.Height, PixelFormat.Format24bppRgb);Graphics g = Graphics.FromImage(bnew);g.DrawImage(b, 0, 0);g.Dispose();
<1> 图片灰度化

这是图像识别通常都要走的第一步,图片灰度化有助于减少后续对rgb的计算量,同时也方便我们进行二值化,在aforge中有专门的类一步搞定,简洁方便。

//灰度化b = new Grayscale(0.2125, 0.7154, 0.0721).Apply(b);
<2>二值化

二值化顾名思义就是二种值,比如非白即黑,非黑即白,那么白和黑的标准就需要提供一个阈值,大于或者小于怎么样,在aforge同样 也有相似的类进行处理。

//二值化b = new Threshold(50).Apply(b);
<3> 去噪点

从上面的图片可以发现有很多红点点,搞得像皮肤病一样,仔细观察可以看到这种噪点具有独立,体积小的特征,所以判断的标准就是如果图中某个区块的大小在我设置的阈值内,就将其去掉,同样也有专门的类进行处理。

//去噪点new BlobsFiltering(1, 1, b.Width, b.Height).Apply(b);

<4> 切割图片

切图片的好处在于我们需要知道真正要识别的元素的有效范围是多大,同时也方便我们将这些图片作为模板保存下来。

代码如下:

/// <summary>/// 按照 Y 轴线 切割/// (丢弃等于号)/// </summary>/// <param name="?"></param>/// <returns></returns>public List<Bitmap> Crop_Y(Bitmap b){var list = new List<Bitmap>();//统计每一列的“1”的个数,方便切除int[] cols = new int[b.Width];/**  纵向切割*/for (int x = 0; x < b.Width; x++){for (int y = 0; y < b.Height; y++){//获取当前像素点像素var pixel = b.GetPixel(x, y);//说明是黑色点if (pixel.R == 0){cols[x] = ++cols[x];}}}int left = 0, right = 0;for (int i = 0; i < cols.Length; i++){//说明该列有像素值(为了防止像素干扰,去噪后出现空白的问题,所以多判断一下,防止切割成多个)if (cols[i] > 0 || (i + 1 < cols.Length && cols[i + 1] > 0)){if (left == 0){//切下来图片的横坐标leftleft = i;}else{//切下来图片的横坐标rightright = i;}}else{//说明已经有切割图了,下面我们进行切割处理if ((left > 0 || right > 0)){Crop corp = new Crop(new Rectangle(left, 0, right - left + 1, b.Height));var small = corp.Apply(b);//居中,将图片放在20*50的像素里面list.Add(small);}left = right = 0;}}return list;}/// <summary>/// 按照 X 轴线 切割/// </summary>/// <param name="b"></param>/// <returns></returns>public List<Bitmap> Crop_X(List<Bitmap> list){var corplist = new List<Bitmap>();//再对分割的图进行上下切割,取出上下的白边foreach (var segb in list){//统计每一行的“1”的个数,方便切除int[] rows = new int[segb.Height];/**  横向切割*/for (int y = 0; y < segb.Height; y++){for (int x = 0; x < segb.Width; x++){//获取当前像素点像素var pixel = segb.GetPixel(x, y);//说明是黑色点if (pixel.R == 0){rows[y] = ++rows[y];}}}int bottom = 0, top = 0;for (int y = 0; y < rows.Length; y++){//说明该行有像素值(为了防止像素干扰,去噪后出现空白的问题,所以多判断一下,防止切割成多个)if (rows[y] > 0 || (y + 1 < rows.Length && rows[y + 1] > 0)){if (top == 0){//切下来图片的top坐标top = y;}else{//切下来图片的bottom坐标bottom = y;}}else{//说明已经有切割图了,下面我们进行切割处理if ((top > 0 || bottom > 0) && bottom - top > 0){Crop corp = new Crop(new Rectangle(0, top, segb.Width, bottom - top + 1));var small = corp.Apply(segb);corplist.Add(small);}top = bottom = 0;}}}return corplist;}

<5> 图片精处理

这里要注意的是,比如数字 “2”,切除上下左右的空白后,再加上噪点的干扰,不一定每次切下来的图片大小都一样,所以这里为了方便更好的识别,我们需要重置下图片的大小,并且将 “数字2” 进行文字居中。


/// <summary>/// 重置图片的指定大小并且居中/// </summary>/// <param name="list"></param>/// <returns></returns>public List<Bitmap> ToResizeAndCenterIt(List<Bitmap> list, int w = 20, int h = 20){List<Bitmap> resizeList = new List<Bitmap>();for (int i = 0; i < list.Count; i++){//反转一下图片list[i] = new Invert().Apply(list[i]);int sw = list[i].Width;int sh = list[i].Height;Crop corpFilter = new Crop(new Rectangle(0, 0, w, h));list[i] = corpFilter.Apply(list[i]);//再反转回去list[i] = new Invert().Apply(list[i]);//计算中心位置int centerX = (w - sw) / 2;int centerY = (h - sh) / 2;list[i] = new CanvasMove(new IntPoint(centerX, centerY), Color.White).Apply(list[i]);resizeList.Add(list[i]);}return resizeList;}

其实精处理后,这些图片就可以作为我们的模板库的图片了,可以将每张模板图都标记下具体的数字,后续我们再遇到时,计算下其相似度就可以了,下面就是已经制作好的模板。

<6> 模板匹配识别

既然模板图片都制作好了,一切都差不多水到渠成了,下次需要识别的验证码我都切好后做成精图片再跟模板进行匹配,在 afroge 里面有一个 ExhaustiveTemplateMatching,专门用来进行模板匹配用的,很方便。


ExhaustiveTemplateMatching templateMatching = new ExhaustiveTemplateMatching(0.9f);

这里的 0.9f 就是设定的阈值,只有大于0.9,我才认为该模板与目标图片相似,然后在所有大于0.9的相似度中取到最大的一个作为我们最后识别的图像。


var files = Directory.GetFiles(Environment.CurrentDirectory + "\\Template\\");var templateList = files.Select(i => { return new Bitmap(i); }).ToList();var templateListFileName = files.Select(i => { return i.Substring(30, 1); }).ToList();var result = new List<string>();ExhaustiveTemplateMatching templateMatching = new ExhaustiveTemplateMatching(0.9f);//这里面有四张图片,进行四张图的模板匹配for (int i = 0; i < list.Count; i++){float max = 0;int index = 0;for (int j = 0; j < templateList.Count; j++){var compare = templateMatching.ProcessImage(list[i], templateList[j]);if (compare.Length > 0 && compare[0].Similarity > max){//记录下最相似的max = compare[0].Similarity;index = j;}}result.Add(templateListFileName[index]);}

最后的效果还是不错的,识别率基本 100% 吧。

这篇关于用 aforge.net 小试一下验证码识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/297670

相关文章

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

Spring 验证码(kaptcha)

首先引入需要的jar包: <dependency><groupId>com.github.axet</groupId><artifactId>kaptcha</artifactId><version>0.0.9</version></dependency> 配置验证码相关设置: <bean id="captchaProducer" class="com.

Clion不识别C代码或者无法跳转C语言项目怎么办?

如果是中文会显示: 此时只需要右击项目,或者你的源代码目录,将这个项目或者源码目录标记为项目源和头文件即可。 英文如下:

.NET 自定义过滤器 - ActionFilterAttribute

这个代码片段定义了一个自定义的 ASP.NET Core 过滤器(GuardModelStateAttribute),用于在控制器动作执行之前验证模型状态(ModelState)。如果模型状态无效,则构造一个 ProblemDetails 对象来描述错误,并返回一个 BadRequest 响应。 代码片段: /// <summary>/// 验证 ModelState 是否有效/// </

BERN2(生物医学领域)命名实体识别与命名规范化工具

BERN2: an advanced neural biomedical named entity recognition and normalization tool 《Bioinformatics》2022 1 摘要 NER和NEN:在生物医学自然语言处理中,NER和NEN是关键任务,它们使得从生物医学文献中自动提取实体(如疾病和药物)成为可能。 BERN2:BERN2是一个工具,

行为智能识别摄像机

行为智能识别摄像机 是一种结合了人工智能技术和监控摄像技术的先进设备,它能够通过深度学习算法对监控画面进行实时分析,自动识别和分析监控画面中的各种行为动作。这种摄像机在安防领域有着广泛的应用,可以帮助监控人员及时发现异常行为,并采取相应的措施。 行为智能识别摄像机可以有效预防盗窃事件。在商场、超市等公共场所安装这种摄像机,可以通过识别异常行为等情况,及时报警并阻止不安全行为的发生

flutter开发实战-flutter build web微信无法识别二维码及小程序码问题

flutter开发实战-flutter build web微信无法识别二维码及小程序码问题 GitHub Pages是一个直接从GitHub存储库托管的静态站点服务,‌它允许用户通过简单的配置,‌将个人的代码项目转化为一个可以在线访问的网站。‌这里使用flutter build web来构建web发布到GitHub Pages。 最近通过flutter build web,通过发布到GitHu