浏览主站 | 站长合租 | 新闻资讯 | 站长学院 | 站长盈利 | HTML教程 | 网址导航 | 站长周刊 | 会员投稿 | 滚动新闻 | RSS
发新话题
打印

两个获取http页面的c#函数

两个获取http页面的c#函数

[[wiki]wiki[/wiki]][/wiki]埋头苦干一天终于搞定!一个用C#写的[wiki]windows[/wiki]应用[wiki]程序[/wiki],作用嘛,就是对asp程序已知的20种漏洞进行扫描,显示源程序。在这个应用程序中用到两种获得http页面的方法,一种是直接用httpwebreq[wiki]UE[/wiki]st[wiki]类[/wiki],而另一种是同[wiki]服务器[/wiki]通过[wiki]TCP[/wiki]/ip建立socket连接,直接查询[wiki]端口[/wiki]80 , 为此我写了以蟍wiki]铝[/wiki]礁龊谝桓霰冉霞虻ィ问挥幸桓觯褪且蟮腫wiki]URL[/wiki] , 另外一个比较复杂,也很通用,不仅可以请求http页面,还可以和其他端口[wiki]通信[/wiki],如端口43的whois,端口25的smtp,端口21的[wiki]FTP[/wiki]甚至pop3等等,三个参数分别是主机名,请求命令和端口。好了,看程序吧。

        //获取http页面函数
        private string Get_Http(string a_strUrl)
        {
            string strResult ;
            HttpWebRequest myReq = (HttpWebRequest)
                                   WebRequestFactory.Create(a_strUrl) ;

            try
            {
                HttpWebResponse HttpWResp = (HttpWebResponse)myReq.GetResponse();
                Stream myStream = HttpWResp.GetResponseStream () ;

                StreamReader sr = new StreamReader(myStream , Encoding.Default);
                StringBuilder strBuilder = new StringBuilder();
                while (-1 != sr.Peek())
                {
                    strBuilder.Append(sr.ReadLine() "rn");
                }
               
                strResult = strBuilder.ToString();
            }
            catch(Exception e[wiki]XP[/wiki])
            {
                 strResult = "错误:"   exp.Message ;
            }

            return strResult ;
            
        }


        //通过同server建立tcp/ip连接,发送socket命令
        private string Get_Socket_Request(string a_strServer , string a_strRequest , Int32 a_intPort)
        {
            //Set up variables and String to write to the server
            Encoding ASCII = Encoding.Default ;
            string Get = a_strRequest   "Connection: Closernrn";
            //string Get =
            Byte[] ByteGet = ASCII.GetBytes(Get);
            Byte[] RecvBytes = new Byte[256];
            String strRetPage = null;

            // IPAddress and IPEndPoint represent the endpoint that will
            //   receive the request
            IPAddress hostadd = DNS.Resolve(a_strServer.Substring(7 ,a_strServer.Length - 7));
            IPEndPoint EPhost = new IPEndPoint(hostadd, a_intPort);

            //Create the Socket for sending data over TCP
            Socket s = new Socket(AddressFamily.AfINet, Socket[wiki]type[/wiki].SockStream,
                                    ProtocolType.ProtTCP );

            // Connect to host using IPEndPoint
            if (s.Connect(EPhost) != 0)
            {
                strRetPage = "Unable to connect to host";
                return strRetPage;
            }

            // Sent the GET text to the host
            s.Send(ByteGet, ByteGet.Length, 0);

            // Receive the page, loop until all bytes are received
            Int32 bytes = s.Receive(RecvBytes, RecvBytes.Length, 0);
            strRetPage = strRetPage   ASCII.GetString(RecvBytes, 0, bytes);

            while (bytes > 0)
            {
                bytes = s.Receive(RecvBytes, RecvBytes.Length, 0);
                strRetPage = strRetPage   ASCII.GetString(RecvBytes, 0, bytes);
            }

            return strRetPage ;
        }


那个扫描漏洞的应用程序包括[wiki]源代码[/wiki]我将整理后放到我的站点,如果你需要可以来下载。

TOP

发新话题