• <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.¢%

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

            穿透代理服務器編程

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

            //使用到的結構
            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("不能連接到代理服務器!");
            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("不能連接到代理服務器!");
            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("代理服務器用戶驗證不成功!");
            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("不能連接到代理服務器!");
            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)); //發送請求
            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;
            }
            我們一般先與代理服務器連通,然后向代理服務器發送代理驗證的用戶名和密碼
            (如果需要,如Socks5代理),驗證成功后,再向代理服務器發送需要連接的目的
            地址和端口。以上代碼僅用于TCP方式連接
            久久精品国产亚洲7777| 精品国际久久久久999波多野 | 久久精品国产亚洲av高清漫画| 中文字幕久久欲求不满| 久久久久亚洲av成人无码电影| 久久久精品久久久久特色影视| 亚洲AV无码久久精品成人| 69SEX久久精品国产麻豆| 久久久久久一区国产精品| 99久久做夜夜爱天天做精品| 久久国产乱子伦免费精品| 久久久精品日本一区二区三区| 精品久久久久久中文字幕大豆网| 91视频国产91久久久| 精品国产乱码久久久久软件| 香蕉久久夜色精品国产小说| 久久久久久久久久久精品尤物| 久久综合久久久| 国产精品对白刺激久久久| 亚洲性久久久影院| 久久av免费天堂小草播放| 国内精品人妻无码久久久影院| 久久亚洲国产成人影院网站| 久久精品国内一区二区三区| 久久青青草原精品国产| 亚洲国产婷婷香蕉久久久久久| 国产精品成人99久久久久 | 久久成人国产精品一区二区| 99久久中文字幕| 精品无码久久久久久尤物| 日韩人妻无码一区二区三区久久| 亚洲国产精品成人AV无码久久综合影院 | 亚洲人成无码网站久久99热国产| 亚洲午夜精品久久久久久人妖| 精品国产VA久久久久久久冰 | 久久发布国产伦子伦精品| 中文字幕日本人妻久久久免费 | 99久久伊人精品综合观看| 97久久精品人妻人人搡人人玩| 国内精品久久人妻互换| 久久96国产精品久久久|