实例程序实现对CSDN验证码的识别

17 篇文章 0 订阅
5 篇文章 3 订阅

 简单验证码的识别:CSDN验证码的识别取图像部分,ASP.NET_SessionID=这个值你要自己取这样的话就可以做成自动登录了

 

csdn可以说的技术界的老大了,而CSDN的验证码识别如下,看如下代码

简单验证码的识别:CSDN验证码的识别
取图像部分,ASP.NET_SessionID=这个值你要自己取这样的话就可以做成自动登录了

private Stream geturl(ref string str)
        {
            string url = "http://www.csdn.net/member/ShowExPwd.aspx";
            WebRequest myWebRequest = WebRequest.Create(url);
        
            myWebRequest.Headers.Add("Cookie","ASP.NET_SessionId=tr0p4g45xa0qzg45bmlqprnn");
            WebResponse myWebResponse = myWebRequest.GetResponse();
            Stream ReceiveStream = myWebResponse.GetResponseStream();    
            str=myWebResponse.Headers[6];
            return ReceiveStream;
            
        }
        private string getNumber()
        {
            string str;
            str="";
            Stream geturlStream =geturl(ref str);
            Bitmap map = new Bitmap(geturlStream,false);
            pictureBox1.Image = (Image)map;
            csdn csdn1= new csdn ();
            return csdn1.readMap(map)+str;
        }


 

验证码识别部分(很简单类型的):

分割图片变成四个部分.

接下来判断象素点.再判断特征点 100%识别

using System;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Drawing.Imaging;

namespace binbin
{
    /** <summary>
    /// Class1 的摘要说明。
    /// </summary>
    public class csdn
    {
        public csdn()
        {
            
        }
        public string readMap(Bitmap image)
        {
            string str;
            RectangleF[] block=new RectangleF[4];
            block[0]=new Rectangle(3,0,8,18);
            block[1]=new Rectangle(12,0,8,18);
            block[2]=new Rectangle(21,0,8,18);
            block[3]=new Rectangle(30,0,8,18);
            //分别克隆图片的四个部分    
            Bitmap[] s=new Bitmap[4];
            s[0]=image.Clone(block[0],PixelFormat.DontCare);
            s[1]=image.Clone(block[1],PixelFormat.DontCare);
            s[2]=image.Clone(block[2],PixelFormat.DontCare);
            s[3]=image.Clone(block[3],PixelFormat.DontCare);
            str=ReadMap(s[0]).ToString();
            str=str+ReadMap(s[1]).ToString();
            str=str+ReadMap(s[2]).ToString();
            str=str+ReadMap(s[3]).ToString();
            return str;
        }
        private int ReadMap(Bitmap k)
        {
            int n=0;
            int m=0;
            Color color;
            for(int i=7; i>=0;i--)
            {
                for( int j=17; j>=0;j--)
                {
                    color=k.GetPixel(i,j);
                    if (color.GetBrightness()==1.0)
                    {
                        n=n+1;//白色点
                    }
                    else
                    {
                        m=m+1;//蓝色点
                    }

                }
            }
            switch(m)
            {
                case 22:
                    color=k.GetPixel(7,12);
                    if (color.GetBrightness()==1)
                    {
                        return 2;
                    }
                    else
                    {
                        return 3;
                    }
                case 25:
                    return 4;
                case 26:
                    return 5;
                case 28:
                    return 0;
                case 30:
                    return 8;
                case 18: //18 29还要特殊处理
                    color=k.GetPixel(7,4);
                    if (color.GetBrightness()==1)
                        {
                            return 1;
                        }
                    else
                        {
                            return 7;
                        }
                case 29:

                    color=k.GetPixel(1,15);
                    if (color.GetBrightness()==1)
                    {
                        return 6;
                    }
                    else
                    {
                        return 9;
                    }
                default:
                    break;
            }
            return -1;
        }
    }
}


 

http://blog.csdn.net/xiaoxiao108/article/details/7226120 前些天,12306这个网站挺火的,看到网上出现了各种各样的登陆、订票插件跟程序。虽然没经历过春运,看到网上各种各样的插件跟工具挺有意思的,下载了几个看了看,都挺不错的。印象中有个java版本的订票程序里面有个验证码识别功能,用tesseract-ocr来识别验证码的,如果验证码不是很复杂识别效果还可以。 开发环境 vs2008 开发语言C# 使用方法很简单 1.下载tesseract 的.net 类库tessnet2_32.dll ,添加引用。 http://www.pixel-technology.com/freeware/tessnet2/ 2.下载tesseract 相对应的语言包。 http://code.google.com/p/tesseract-ocr/downloads/list 3.调用tesseract 的方法进行识别。 具体代码 1.读取网上的验证码到pictureBox中 //string url = "https://dynamic.12306.cn/otsweb/passCodeAction.do?rand=lrand"; string url = "http://static.baixing.net/pages/mobile.php?c=bcqsFelX+vKQcrnIbhyDYQ==/2.jpg"; HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; HttpWebResponse response = request.GetResponse() as HttpWebResponse; System.IO.Stream responseStream = response.GetResponseStream(); this.pictureBox1.Image = Image.FromStream(responseStream); 2.OCR类 public class Ocr { public void DumpResult(List result) { foreach (tessnet2.Word word in result) //Console.WriteLine("{0} : {1}", word.Confidence, word.Text); MessageBox.Show(string.Format("{0} : {1}", word.Confidence, word.Text)); } public List DoOCRNormal(Bitmap image, string lang) { tessnet2.Tesseract ocr = new tessnet2.Tesseract(); ocr.Init(null, lang, false); List result = ocr.DoOCR(image, Rectangle.Empty); DumpResult(result); return result; } System.Threading.ManualResetEvent m_event; public void DoOCRMultiThred(Bitmap image, string lang) { tessnet2.Tesseract ocr = new tessnet2.Tesseract(); ocr.Init(null, lang, false); // If the Oc
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值