• <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.¢% 閱讀(525) 評論(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方式連接
            亚洲国产精品无码久久久蜜芽 | 99久久无码一区人妻a黑| 无码国产69精品久久久久网站| 国产99久久精品一区二区| 精品久久久无码中文字幕天天| 日本精品久久久久影院日本| 亚洲AV无码久久精品蜜桃| 91亚洲国产成人久久精品网址| 一本久久a久久精品综合香蕉| 成人资源影音先锋久久资源网| 亚洲国产成人久久综合野外| 国产精品禁18久久久夂久| 久久久久久伊人高潮影院| 国产精品丝袜久久久久久不卡| 蜜臀久久99精品久久久久久小说| 精品久久久久国产免费| 久久精品国产影库免费看| 久久久久久精品久久久久| 久久久久国产一区二区三区| 无码超乳爆乳中文字幕久久 | 久久综合给合久久狠狠狠97色69| 久久99精品国产麻豆不卡| 丁香五月网久久综合| 新狼窝色AV性久久久久久| 国产欧美久久久精品影院| 久久无码国产| 久久99精品九九九久久婷婷| 久久91精品国产91久久小草| 色综合久久综合中文综合网| 2021久久精品免费观看| 久久影视综合亚洲| 久久夜色撩人精品国产| 色欲综合久久躁天天躁| 婷婷久久综合| 亚洲欧美一区二区三区久久| 亚洲欧美日韩中文久久 | 久久国产精品免费| 精品国产热久久久福利| 国产免费久久精品99久久| 久久精品国产精品亚洲下载| 久久久无码精品亚洲日韩软件|