インスタンスプログラムはCSDN検証コードの識別を実現する


簡易認証コードの識別: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;
        }

 
認証コード識別部(簡単なタイプ):
分割画像は4つの部分になる.
次に画素点を判断する.再判断特徴点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;
        }
    }
}