• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉(zhuǎn),開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            穿透代理服務(wù)器編程

            Posted on 2009-10-15 23:38 S.l.e!ep.¢% 閱讀(519) 評論(0)  編輯 收藏 引用 所屬分類: NetWork
            在日常工作和學(xué)習(xí)的時,我們時常要和代理服務(wù)器打交道,
            比如通過企業(yè)、校園局域網(wǎng)上網(wǎng)的時候,一般代理服務(wù)器都支持幾種常見的代理協(xié)議標準,如Socks4,Socks5,Http代理,其中Socks5需要用戶驗證,代理起來比較復(fù)雜。
            我在查閱一些文檔和相關(guān)資料后,總結(jié)一些TCP協(xié)議穿透代理服務(wù)器的程序,希望能對大家有所幫助。

            //使用到的結(jié)構(gòu)
            struct sock4req1
            {
            char VN;
            char CD;
            unsigned short Port;
            unsigned long IPAddr;
            char other;
            };

            struct sock4ans1
            {
            char VN;
            char CD;
            };

            struct sock5req1
            {
            char Ver;
            char nMethods;
            char Methods;
            };

            struct sock5ans1
            {
            char Ver;
            char Method;
            };

            struct sock5req2
            {
            char Ver;
            char Cmd;
            char Rsv;
            char Atyp;
            char other;
            };

            struct sock5ans2
            {
            char Ver;
            char Rep;
            char Rsv;
            char Atyp;
            char other;
            };

            struct authreq
            {
            char Ver;
            char Ulen;
            char Name;
            char PLen;
            char Pass;
            };

            struct authans
            {
            char Ver;
            char Status;
            };

            //通過Socks4方式代理
            if( !ClientSock.Connect( g_ProxyInfo.m_strProxyIP,g_ProxyInfo.m_nProxyPort) )
            {
            m_sError = _T("不能連接到代理服務(wù)器!");
            ClientSock.Close();
            return FALSE;
            }
            char buff;
            memset(buff,0,100);
            struct sock4req1 *m_proxyreq;
            m_proxyreq = (struct sock4req1 *)buff;
            m_proxyreq->VN = 4;
            m_proxyreq->CD = 1;
            m_proxyreq->Port = ntohs(GetPort());
            m_proxyreq->IPAddr = inet_addr(GetServerHostName());
            ClientSock.Send(buff,9);
            struct sock4ans1 *m_proxyans;
            m_proxyans = (struct sock4ans1 *)buff;
            memset(buff,0,100);
            ClientSock.Receive(buff,100);
            if(m_proxyans->VN != 0 || m_proxyans->CD != 90)
            {
            m_sError = _T("通過代理連接主站不成功!");
            ClientSock.Close();
            return FALSE;
            }




            //通過Socks5方式代理
            if( !ClientSock.Connect( g_ProxyInfo.m_strProxyIP,g_ProxyInfo.m_nProxyPort) )
            {
            m_sError = _T("不能連接到代理服務(wù)器!");
            ClientSock.Close();
            return FALSE;
            }
            char buff;
            struct sock5req1 *m_proxyreq1;
            m_proxyreq1 = (struct sock5req1 *)buff;
            m_proxyreq1->Ver = 5;
            m_proxyreq1->nMethods = 2;
            m_proxyreq1->Methods = 0;
            m_proxyreq1->Methods = 2;
            ClientSock.Send(buff,4);
            struct sock5ans1 *m_proxyans1;
            m_proxyans1 = (struct sock5ans1 *)buff;
            memset(buff,0,600);
            ClientSock.Receive(buff,600);
            if(m_proxyans1->Ver != 5 || (m_proxyans1->Method!=0 && m_proxyans1->Method!=2))
            {
            m_sError = _T("通過代理連接主站不成功!");
            ClientSock.Close();
            return FALSE;
            }
            if(m_proxyans1->Method == 2)
            {
            int nUserLen = strlen(g_ProxyInfo.m_strProxyUser);
            int nPassLen = strlen(g_ProxyInfo.m_strProxyPass);
            struct authreq *m_authreq;
            m_authreq = (struct authreq *)buff;
            m_authreq->Ver = 1;
            m_authreq->Ulen = nUserLen;
            strcpy(m_authreq->Name,g_ProxyInfo.m_strProxyUser);
            m_authreq->PLen = nPassLen;
            strcpy(m_authreq->Pass,g_ProxyInfo.m_strProxyPass);
            ClientSock.Send(buff,513);
            struct authans *m_authans;
            m_authans = (struct authans *)buff;
            memset(buff,0,600);
            ClientSock.Receive(buff,600);
            if(m_authans->Ver != 1 || m_authans->Status != 0)
            {
            m_sError = _T("代理服務(wù)器用戶驗證不成功!");
            ClientSock.Close();
            return FALSE;
            }
            }
            struct sock5req2 *m_proxyreq2;
            m_proxyreq2 = (struct sock5req2 *)buff;
            m_proxyreq2->Ver = 5;
            m_proxyreq2->Cmd = 1;
            m_proxyreq2->Rsv = 0;
            m_proxyreq2->Atyp = 1;
            unsigned long tmpLong = inet_addr(GetServerHostName());
            unsigned short port = ntohs(GetPort());
            memcpy(m_proxyreq2->other,&tmpLong,4);
            memcpy(m_proxyreq2->other+4,&port,2);
            ClientSock.Send(buff,sizeof(struct sock5req2)+5);
            struct sock5ans2 *m_proxyans2;
            memset(buff,0,600);
            m_proxyans2 = (struct sock5ans2 *)buff;
            ClientSock.Receive(buff,600);
            if(m_proxyans2->Ver != 5 || m_proxyans2->Rep != 0)
            {
            m_sError = _T("通過代理連接主站不成功!");
            ClientSock.Close();
            return FALSE;
            }




            //通過HTTP方式代理
            if( !ClientSock.Connect( g_ProxyInfo.m_strProxyIP,g_ProxyInfo.m_nProxyPort) )
            {
            m_sError = _T("不能連接到代理服務(wù)器!");
            ClientSock.Close();
            return FALSE;
            }
            char buff;
            sprintf( buff, "%s%s:%d%s","CONNECT ",GetServerHostName(),GetPort(),"
            HTTP/1.1rnUser-Agent: MyApp/0.1rnrn");
            ClientSock.Send(buff,strlen(buff)); //發(fā)送請求
            memset(buff,0,600);
            ClientSock.Receive(buff,600);
            if(strstr(buff, "HTTP/1.0 200 Connection established") == NULL) //連接不成功
            {
            m_sError = _T("通過代理連接主站不成功!");
            ClientSock.Close();
            return FALSE;
            }
            我們一般先與代理服務(wù)器連通,然后向代理服務(wù)器發(fā)送代理驗證的用戶名和密碼
            (如果需要,如Socks5代理),驗證成功后,再向代理服務(wù)器發(fā)送需要連接的目的
            地址和端口。以上代碼僅用于TCP方式連接
            国产精品久久久久久| 亚洲欧美成人综合久久久| 一级做a爰片久久毛片免费陪| 久久亚洲欧洲国产综合| 99久久综合狠狠综合久久止| 欧美精品一本久久男人的天堂| 久久久久国产一区二区| 久久精品国产亚洲av日韩| 亚洲精品成人久久久| 久久精品人人做人人爽97| 精品久久久久久久久久久久久久久| 婷婷久久久亚洲欧洲日产国码AV| 人人狠狠综合久久亚洲婷婷| 亚洲中文久久精品无码| 亚洲精品国产第一综合99久久| 欧美777精品久久久久网| 18禁黄久久久AAA片| 精品国产99久久久久久麻豆| 精品久久久久成人码免费动漫| 久久精品国产亚洲沈樵| 精品无码久久久久久国产| 久久综合综合久久综合| 国产婷婷成人久久Av免费高清| 久久精品夜夜夜夜夜久久| 一本久久a久久精品综合香蕉| 亚洲国产精品一区二区久久| 97超级碰碰碰碰久久久久| 久久天天躁狠狠躁夜夜avapp| 亚洲精品tv久久久久久久久久| 久久久99精品成人片中文字幕| 久久成人精品视频| 久久免费小视频| 9191精品国产免费久久| 久久精品国产亚洲沈樵| 国产精品一区二区久久精品| 精品久久久久久久无码| 精品久久久久久国产潘金莲| av色综合久久天堂av色综合在 | 国产99久久久久久免费看| 国产无套内射久久久国产| 久久久久综合网久久|