• 自动投票中验证码识别问题初探


    现在很多网站投票、发帖都采取了验证码机制,如果验证码位置角度是固定的话,就可以采取先采样生成字模,然后进行对比,最后得到对应的验证码。这种方法基本上可以不用除噪,而且识别率达到百分之百准确。下面是我写的验证码识别代码:
    Static Words As Byte
    Dim i As Integer
    Dim m As Integer
    Dim n As Integer
    Dim FNum As Integer
    Dim ImgStr As String
    Dim Kuan As Integer
    Dim Gao As Integer
    Dim lColor As Long
    Dim MaNub As Integer
    Dim DImgStr As String
    Dim ZuiHouMa As String
    Dim YZMa As Integer
    Dim TopKong As Integer
    Dim LeftKong As Integer
    Dim RightKong As Integer
    Dim CYL(0 To 15As Integer '差异率
    '
    验证图片宽度55,高度16,从第六个点(编号5)开始,到第50个点(编号49)结束,共五个字,5*9=45 上空4下空2
    '
    验证图片宽度100 高度25 从26点开始,每字宽9,右空2,上空5,高13
    MaNub = 5   '一幅图里有几个码
    Kuan = 9
    Gao 
    = 13
    TopKong 
    = 5
    LeftKong 
    = 26
    RightKong 
    = 2
    WordX 
    = (Me.Left + Picture1.Left) / Screen.TwipsPerPixelX + LeftKong
    WordY 
    = (Me.Top + Picture1.Top) / Screen.TwipsPerPixelY + TopKong
    'MsgBox WordX & WordY

    'ls = SetPixel(GetDC(0), WordX, WordY, vbGreen)
    WordX = LeftKong
    WordY 
    = TopKong

    ZuiHouMa 
    = ""

    For i = 0 To MaNub - 1
            
        ImgStr 
    = ""
        
        
    For m = 0 To Gao - 1
            
    For n = 0 To Kuan - 1
                lColor 
    = GetPixel(Picture1.hdc, WordX + n, WordY + m)
                
    If GetRedValue(lColor) > 100 And GetGreenValue(lColor) < 100 And GetBlueValue(lColor) < 100 Then
                    ImgStr 
    = ImgStr & "1"
                
    Else
                    ImgStr 
    = ImgStr & "0"
                
    End If
            
    Next n
        
    Next m

        YZMa 
    = 9
        CYL(YZMa) 
    = 100
        
    For m = 0 To 9
            CYL(m) 
    = 0
            
    For n = 0 To Kuan * Gao - 1
                
    If (Mid(FontDat(m), n + 11= "1"And (Mid(ImgStr, n + 11= "0"Then CYL(m) = CYL(m) + 1
                
    If (Mid(FontDat(m), n + 11= "0"And (Mid(ImgStr, n + 11= "1"Then CYL(m) = CYL(m) + 1
            
    Next n
            
    If CYL(m) < CYL(YZMa) Then YZMa = m
        
    Next m
        ZuiHouMa 
    = ZuiHouMa & Trim(Hex(YZMa))
        WordX 
    = WordX + Kuan + RightKong
                
    Next i
    Text1.Text 
    = ZuiHouMa


    程序运行界面如下:


    注:界面借用了网上下载的一个程序。。但识别内核是我自己写的。

    DEMO程序如下:
    http://my82163.51.net/readcode.rar

  • 相关阅读:
    《Maven实战》文字版[PDF]
    spring管理的类如何调用非spring管理的类
    从session中获取当前用户的工具类
    WebService,ESB笔记
    Activiti
    ElasticSearch最全分词器比较及使用方法
    [ElasticSearch]Java API 之 滚动搜索(Scroll API)
    从html富文本中提取纯文本
    Jetty启动报Error scanning entry META-INF/versions/9/org/apache/logging/log4j/util/ProcessIdUtil.class
    elasticsearch: 创建mapping
  • 原文地址:https://www.cnblogs.com/spy/p/329926.html
Copyright © 2020-2023  润新知