首 页   · 站长博客 · 用户注册 · 会员登陆  · 会员排行  ·最新主题  ·最近回复  精华区  版权声明  ·论坛管理
  当前登录身份:游客,请先登录。  笔名: 口令: 验证码:   
楼 主  index »  web服务器安全与维护 » 验证码识别技术杂谈  


  作者:海天旭日
  注册时间:2004-04-06
  主题/回复:69/145
  积分:1508
  等级:★★★★(八级)
  称号:论坛才子

  xiaopb@163.com
  11843938
  www.xpb.cn

 

 发表:2008-06-18 18:14:10 阅读 7220 次 回复 7 次 得分7  |   字号 字色
验证码识别技术杂谈
一、验证码的基本知识
枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_N&y
    1. 验证码的主要目的是强制人机交互来抵御机器自动化攻击的。
    峇&Otilde
    2. 大部分的验证码设计者并不得要领,不了解图像处理,机器视觉,模式识别,人工智能
的基本概念。
    峇&Otilde
    3. 利用验证码,可以发财,当然要犯罪:比如招商银行密码只有6位,验证码形同虚设,计
算机很快就能破解一个有钱的账户,很多帐户是可以网上交易的。
    峇&Otilde
    4. 也有设计的比较好的,比如Yahoo,Google,Microsoft等。而国内Tencent的中文验证
码虽然难,但算不上好。
枾e剉匏Ь酹 Ë??薹嘌鹒:|ô??騳aa岿
二、人工智能,模式识别,机器视觉,图像处理的基本知识

    1)主要流程:
    枾e剉匏Ь酹 Ë??薹嘌鹒:|ô??騳aa岿
    比如我们要从一副图片中,识别出验证码;比如我们要从一副图片中,检测并识别出一张
人脸。 大概有哪些步骤呢?

    1.图像采集:验证码呢,就直接通过HTTP抓HTML,然后分析出图片的url,然后下载保存就
可以了。 如果是人脸检测识别,一般要通过视屏采集设备,采集回来,通过A/D转操作,存为
数字图片或者视频频。
    枾e剉匏Ь酹 Ë??薹嘌鹒:|ô??騳aa岿
    2.预处理:检测是正确的图像格式,转换到合适的格式,压缩,剪切出ROI,去除噪音,灰度
化,转换色彩空间这些。
    枾e剉垥d?射焫蕒礵 ®?THORN;攩s窟&nti
    3.检测:车牌检测识别系统要先找到车牌的大概位置,人脸检测系统要找出图片中所有
的人脸(包括疑似人脸);验证码识别呢,主要是找出文字所在的主要区域。
    
    4.前处理:人脸检测和识别,会对人脸在识别前作一些校正,比如面内面外的旋转,扭曲
等。我这里的验证码识别,“一般”要做文字的切割
    枾e剉垥d?射焫蕒礵 ®?THORN;攩s窟&nti
    5.训练:通过各种模式识别,机器学习算法,来挑选和训练合适数量的训练集。不是训练
的样本越多越好。过学习,泛化能力差的问题可能在这里出现。这一步不是必须的,有些识
别算法是不需要训练的。
    枾e剉垥d?射焫蕒礵 ®?THORN;攩s窟&nti
    6.识别:输入待识别的处理后的图片,转换成分类器需要的输入格式,然后通过输出的类
和置信度,来判断大概可能是哪个字母。识别本质上就是分类。

    2)关键概念:
    
    图像处理:一般指针对数字图像的某种数学处理。比如投影,钝化,锐化,细化,边缘检测,
二值化,压缩,各种数据变换等等。
    枾e剉垥d?射焫蕒礵 ®?THORN;攩s窟&nti
    1.二值化:一般图片都是彩色的,按照逼真程度,可能很多级别。为了降低计算复杂度,
方便后续的处理,如果在不损失关键信息的情况下,能将图片处理成黑白两种颜色,那就最好
不过了。
    眕寑}??柫X Tlte??pound;漲晿槃v誰
    2.细化:找出图像的骨架,图像线条可能是很宽的,通过细化将宽度将为1,某些地方可能
大于1。不同的细化算法,可能有不同的差异,比如是否更靠近线条中间,比如是否保持联通
行等。
    眕寑}??柫X Tlte??pound;漲晿槃v誰
    3.边缘检测:主要是理解边缘的概念。边缘实际上是图像中图像像素属性变化剧烈的地
方。可能通过一个固定的门限值来判断,也可能是自适应的。门限可能是图像全局的,也可
能是局部的。不能说那个就一定好,不过大部分时候,自适应的局部的门限可能要好点。被
分析的,可能是颜色,也可能是灰度图像的灰度。
眕寑}??柫X Tlte??pound;漲晿槃v誰
    机器视觉:利用计算机来模式实现人的视觉。 比如物体检测,定位,识别。按照对图像
理解的层次的差别,分高阶和低阶的理解。
眕寑}??柫X Tlte??pound;漲晿槃v誰
    模式识别:对事物或者现象的某种表示方式(数值,文字,我们这里主要想说的是数值),
通过一些处理和分析,来描述,归类,理解,解释这些事物,现象及其某种抽象。
眕寑}??柫X Tlte??pound;漲晿槃v誰
    人工智能:这种概念比较宽,上面这些都属于人工智能这个大的方向。简单点不要过分
学院派的理解就是,把人类的很“智能”的东西给模拟出来协助生物的人来处理问题,特别是
在计算机里面。

三、常见的验证码的破解分析
    
    以http://libcaca.zoy.org/wiki/PWNtcha这里PWNtcha项目中的资料为例分析,各种验
证码的破解。(方法很多,仅仅从我个人乍看之下觉得可行的方法来分析)
    
    1)Authimage
     使用的反破解技巧: 
    枾e剉9ei?T &;峇Õ?Otilde;?RMb剉(gl?ÿ}?q_N&y
    1.不连续的点组成字符
    2.有一定程度的倾斜

    设计不好的地方:
    枾e剉9ei?T ÿ峇Õ?RMb剉(gl?ÿ}?q_N&y
    1.通过纵横的直方图投影,可以找到字幕区域
    2.通过Hough变换,适当的参数,可以找到近似的横线,可以做倾斜矫正
    3.字符串的倾斜式面内的,没有太多的破解难度
    4.字母宽度一定,大小一定
    
    2)Clubic
     使用的反破解技巧: 
    枾e剉9ei?T &a;yuml;峇Õ?Otilde;?Rb剉(gl?ÿ}?q_N&y
    1.字符是手写体

    设计不好的地方:
    
    1.检测切割阶段没有任何技术含量,属于设计的比较丑的
    2.只有数字,而且手写体变化不大
    3.表面看起来对识别阶段有难度,仔细分析,发现几乎不用任何高级的训练识别算法,就
固定的招某些像素点是否有色彩就够了

    3)linuxfr.org
     使用的反破解技巧: 枾e剉9ei?T &峇Õ?Otilde;?RMb剉(gl?ÿ}?q_N&y

    1.背景颜色块
    2.前景的横线或矩形

    设计不好的地方:

    1.背景色是单一色块,有形状,通过Region-Growth区域增长来很容易把背景给去掉
    2.前景色是标准的线条,色彩单一
    3.字母无粘连
    4.都是印刷体
枾e剉9ei?T ÿ峇∓Otilde;?Otild;?RMb(gl?&am;yuml;}?q_N&y
    4)Ourcolony
     使用的反破解技巧: 
    
    1.设计的太低级,不屑于去评价

    设计不好的地方:

    1.这种验证码,设计的最丑,但还是能把菜鸟搞定,毕竟学计算机的少,搞这个破解的更
少,正所谓隔行如隔山

    5)LiveJournal
     使用的反破解技巧: 

    1.这个设计略微好点,使用个随机噪音,而且作为前景
    2.字母位置粗细都有变化
枾e剉9ei?T &um;峇≈Otilde;Otilde;?RMb(gl?ÿ}?q_N&y
    设计不好的地方:

    1.字母没有粘连
    2.噪音类型单一
    3.通过在X轴的直方图投影,能准确分割字幕
    4.然后在Y周作直方图投影,能准确定位高度
    5.识别阶段,都是印刷体,简单地很

四、网上的一些高级验证码
    枾e剉9ei?T amp;yuml;峇am;ilde;?Otide;?RM剉(gl?ÿ}?q_N&y
    1)ICQ
     2)IMDb
     3)MS MVPS
  
    4)MVN Forum
  
    这些类型是被很多人认为比较难得类型,分析一下可以发现,字符检测,定位和分割都不
是难。 唯一影响识别率的是IMDBb和MVPS这两类,字体变形略大。
    
    总体来说,这些类型的破解也不难,很容易做到50%以上的识别率。

五、高级验证码的破解分析
    
    时间关系,我简单介绍如何利用图像处理和模式识别技术,自动识别比较高级的验证码。
(以风头正劲的Google为例)
     1)至少从目前的AI的发展程度看,没有简单的做法能自动处理各种不同的验证码,即使
能力很强,那么系统自然也十分复杂强大。所以,要想在很简单的算法实现比较高级的验证
码破解,必须分析不同验证码算法的特点:

    作为一般的图像处理和计算机视觉,会考虑色彩,纹理,形状等直接的特征,同时也考虑
直方图,灰度等统计特征,还考虑FFT,Wavelet等各种变换后的特征。但最终目标都是
Dimension Reduction(降维)然后利于识别,不仅仅是速度的考虑。从图像的角度看,很多系
统都考虑转换为灰度级甚者黑白图片。
 枾e剉;yuml;峇Õ?Otilde;?RMb剉(gl?ÿ}?q_N&衏:ygbL坿T銷b烺 ÿFO瀃E?g枾e剉9ei?T ;峇Õ?Otilde;?RMb剉(gl?&;衏:ygbL坿T銷b烺 ÿFO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
    Google的图片可以看出,颜色变化是虚晃一枪,不存在任何处理难度。难度是字体变形
和字符粘连。
 
    如果能成功的分割字符,那么后期识别无论是用SVM等分类算法,还是分析笔顺比划走向
来硬识别,都相对好做。
 
    2)图像处理和粘连分割
    
    代码中的part1目录主要完成图像预处理和粘连字符分割
    001:将图像从jpg等格式转换为位图便于处理
    002:采用Fix/Adaptive的Threshold门限算法,将图片Bin-Value二值化。
    (可用003算法)
    003:采用OSTU分水岭算法,将图片Bin-Value二值化。
    (更通用,大部分时候效果更好)
    005:获取ROI感兴趣的区域。
    006:Edge Trace边缘跟踪。
    007:Edge Detection边界检测。
    008:Thin细化去骨架。
    009:做了一些Tidy整理。
  (这个一般要根据特定的Captcha算法调整)
    010:做切割,注意图片中红色的交叉点。
    011:将边缘检测和骨干交叉点监测的图像合并。
  (合并过程可以做分析: 比如X坐标偏移门限分析,交叉点区域纹理分析,线条走势分析,
等等各种方法,找出更可能的切分点和分离后部件的组合管理。)
     代码:(代码质量不高,从其他项目拷贝过来,简单修改的。)
剉(gl?ÿ}?q_N&;衏:ygbL坿T銷b;FO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
    查看代码(./pstzine_09_01.txt)

    注: 在这里,我们可以看到,基本的部件(字母是分割开了,但可以造成统一字母的被切
割成多个Component。 一种做法是:利用先验知识,做分割; 另外一种做法是,和第二部分的
识别结合起来。 比如按照从左至右,尝试增加component来识别,如果不能识别而且
component的总宽度,总面积还比较小,继续增加。 当然不排除拒识的可能性。 )

    3)字符部件组合和识别。
枾e剉9ei?T &枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_N&;}?q_N&y
    part2的代码展示了切割后的字母组合,和基于svm的字符识别的训练和识别过程。
Detection.cpp中展示了ImageSpam检测过程中的一些字符分割和组合,layout的分析和利用
的简单技术。 而Google的验证码的识别,完全可以不用到,仅做参考。

    SVM及使用:

    本质上,SVM是一个分类器,原始的SVM是一个两类分类的分类器。可以通过1:1或者1:n
的方式来组合成一个多类分类的分类器。 天生通过核函数的使用支持高维数据的分类。从
几何意义上讲,就是找到最能表示类别特征的那些向量(支持向量SV),然后找到一条线,能最
大化分类的Margin。

    libSVM是一个不错的实现。
    
    训练间断和识别阶段的数据整理和归一化是一样的。 这里的简单做法是:
    
    首先:
    §;yuml;}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
    #define SVM_MAX  +0.999
    #define SVM_MIN  +0.001

    其次:
    
    扫描黑白待识别字幕图片的每个像素,如果为0(黑色,是字母上的像素),那么svm中该位
置就SVM_MAX,反之则反。
枾e剉 ÿFO瀃E?g枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
    最后:

    训练阶段,在svm的input的前面,为该类打上标记,即是那一个字母。
    识别阶段,当然这个类别标记是SVM分类出来。

    注意:

    如果是SVM菜鸟,最好找一个在SVM外边做了包装的工具,比如样本选择,交叉验证,核函
数选择这些,让程序自动选择和分析。

    代码:通过ReginGrowth来提取单个单个的字符,然后开始识别。

    查看代码(./pstzine_09_02.txt)

六、对验证码设计的一些建议
枾e剉yuml;峇Õ?Otilde;?RMb剉(gl?ÿ}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
    1.在噪音等类型的使用上,尽力让字符和用来混淆的前景和背景不容易区分。尽力让坏
人(噪音)长得和好人(字母)一样。
    
    2.特别好的验证码的设计,要尽力发挥人类擅长而AI算法不擅长的。 比如粘连字符的
分割和手写体(通过印刷体做特别的变形也可以)。 而不要一味的去加一些看起来比较复杂
的噪音或者其他的花哨的东西。即使你做的足够复杂,但如果人也难识别,显然别人认为你
是没事找抽型的。
    
    3. 从专业的机器视觉的角度说,验证码的设计,一定要让破解者在识别阶段,反复在低
阶视觉和高阶视觉之间多反复几次才能识别出来。 这样可以大大降低破解难度和破解的准
确率。
枾e剉9ei?T &枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g枾e剉9ei?T ÿ峇Õ?Otilde;?RMb剉(gl?ÿ}?q_Ný衏:ygbL坿T銷b烺 ÿFO瀃E?g;?Otilde;?RMb剉(gl?ÿ}?q_N&y
七、个人郑重申明
    
    1.这个问题,本身是人工智能,计算机视觉,模式识别领域的一个难题。我是虾米,菜得
不能再菜的那种。作为破解者来说,是出于劣势地位。要做的很好,是很难得。总体来说,我
走的是比较学院派的线路,能真正的破解难度比较高的验证码,不同于网上很多不太入流的
破解方法。我能做的只有利用有限的知识,抛砖引玉而已。 很多OCR的技术,特别是离线手
写体中文等文字识别的技术,个人了解有限的很,都不敢在这里乱写。

    2.希望不要把这种技术用于非法用途。

-EOF-
Ph4nt0m Security Team

(本帖被作者修改过2次,最后一次修改时间2008-06-18 18:21:32)

 
 1#楼  
 
  回复人:kiril
  注册时间:2008-06-13
  主题/回复:12/38
  积分:113
  等级:★☆(三级)
  称号:牛刀小试

用户联系方式已设置为保密
 1#楼 发表于2008-06-18 19:35:04  评分:1 

回复给楼主(海天旭日)
海天这个帖子不错,我做沙发了
 2#楼  
 
  回复人:feilang
  注册时间:2004-10-13
  主题/回复:4/34
  积分:463
  等级:★★☆(五级)
  称号:略有小成

   
 2#楼 发表于2008-06-18 20:37:15  评分:1 

回复给楼主(海天旭日)
海天发的,好像都是精品!!!
 3#楼  
 
  回复人:小菜蛋
  注册时间:2008-01-03
  主题/回复:5/35
  积分:721
  等级:★★★(六级)
  称号:声名鹊起

   
 3#楼 发表于2008-12-04 13:39:52  评分:1 

回复给楼主(海天旭日)
帖子真好,不过技术太高,目前还读不懂
 4#楼  
 
  回复人:一起PHP
  注册时间:2004-02-27
  主题/回复:247/1521
  积分:4649
  等级:★★★★★☆(十一级)
  称号:论坛圣人

   
 4#楼 发表于2008-12-29 20:09:31  评分:1 

回复给楼主(海天旭日)
海天出品,必屬精品¡ 支持!
 5#楼  
 
  回复人:75876997
  注册时间:2009-09-02
  主题/回复:0/1
  积分:22
  等级:★(二级)
  称号:初出茅庐

   
 5#楼 发表于2009-09-02 10:32:28  评分:1 

为了这个贴,专门回个复。
为了这个贴,专门回个复。
 6#楼  
 
  回复人:MyStyle
  注册时间:2012-02-20
  主题/回复:0/1
  积分:22
  等级:★(二级)
  称号:初出茅庐

   
 6#楼 发表于2012-02-20 10:12:45  评分:1 

回复给楼主(海天旭日)跪求LiveJournal
的破解方式,本人很菜,最好把破解源码发给我看看,不胜感激。顺便问问怎样破解联通网上营业厅的图片验证码?急需高手指点·····
 7#楼  
 
  回复人:uuwise
  注册时间:2013-03-20
  主题/回复:0/1
  积分:22
  等级:★(二级)
  称号:初出茅庐

   
 7#楼 发表于2013-03-20 22:32:10  评分:1 


优优云验证码识别答题平台介绍
www.uuwise.com
优优云|UU云(中国公司)是全球唯一领先的智能图片识别平台!优优云旨在为广大软件开发者、工作室、普通用户提供即时、精准的验证码图片识别答题服务以快速解决海量验证码识别秒处理的困扰! 7x24小时不间断识别,0~3秒极速返回识别结果,优中取优、专业进取、利润共享、为用户提供最完美解决方案是优优云(UU云)验证码识别平台不变的品质!

为什么要选择优优云?

    1、提高您的软件效率10~1000倍!
    2、提高用户体验,解放用户双手,拒绝手工打码
    3、优秀卓绝利于开发者的分成模式[详情]
    4、高效:7x24h作业,每码平均识别时间0~3秒
    5、稳定:18台智能服务器,8000人校正团队
    6、扣费精准合理:错误码,超时码不扣费
    7、简单接入:提供API,调用Demo,支持C,C++,C#,E,.net,java,delphi,php,AU3,按键精灵等超过26种编程语言轻易接入

  页数1/1首页 « 1 » 末页
  发表回复:您还没有登陆,无法发表回复。请先[登陆]

一起PHP技术联盟 主办:一起PHP 联系方式:站长QQ:4304410 QQ群:8423742 20159565 站长博客 E-mail: nqp@nqp.me 执行时间:0.055sec
SimsmaBBS 2008 (v6.0) Developed by 17php.com,Copyright(C)2003-2010 All rights reserved. 副本授权:一起PHP官方专用版