• <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方式連接
            久久婷婷色综合一区二区| 麻豆成人久久精品二区三区免费| 国内精品久久久久影院优| 2020久久精品国产免费| 久久国产视频99电影| 久久亚洲精品无码aⅴ大香| 久久久久国产精品熟女影院| 欧美激情精品久久久久| 狠狠色丁香久久婷婷综合_中 | 久久一日本道色综合久久| 69SEX久久精品国产麻豆| 一级女性全黄久久生活片免费 | 久久偷看各类wc女厕嘘嘘| 亚洲国产精品久久久久久| 国产A级毛片久久久精品毛片| 精品久久久久久亚洲精品 | 久久精品a亚洲国产v高清不卡| 国产精品综合久久第一页| 久久久久亚洲AV成人片| 亚洲国产天堂久久综合| 久久精品国产精品亚洲下载| 国产亚洲综合久久系列| 香蕉久久av一区二区三区 | 午夜人妻久久久久久久久| 久久久久久青草大香综合精品| 久久免费精品一区二区| 欧洲成人午夜精品无码区久久| 色综合久久天天综线观看| 99久久国产免费福利| 狠狠狠色丁香婷婷综合久久五月| 蜜臀av性久久久久蜜臀aⅴ| 久久无码中文字幕东京热| 亚洲美日韩Av中文字幕无码久久久妻妇| 99久久婷婷国产一区二区| 伊人久久综在合线亚洲2019 | www.久久精品| 久久婷婷五月综合色高清| 97久久精品人妻人人搡人人玩 | 亚洲狠狠婷婷综合久久蜜芽| 香蕉久久夜色精品国产2020| 精品久久久久久久国产潘金莲|