socks代理

http://www.cesdn.net/document/show.aspx?sn=00000000000000000001

穿透代理服务器编程

在网络程序设计过程中,我们经常要与各种类型的代理服务器打交道,比如在企业内部网通过代理去访问Internet网上的服务器等等,一般代理服务器支持几种常见的代理协议标准,如Socks4,Socks5,Http代理,其中Socks5需要用户验证,代理相对复杂。我在查阅RFC文档和相关资料后,特总结一些TCP协议穿透代理服务器的程序片断,希望对大家有所帮助。 


//使用到的结构 

struct sock4req1 

char VN; 

char CD; 

unsigned short Port; 

unsigned long IPAddr; 

char other[1]; 

}; 


struct sock4ans1 

char VN; 

char CD; 

}; 


struct sock5req1 

char Ver; 

char nMethods; 

char Methods[255]; 

}; 


struct sock5ans1 

char Ver; 

char Method; 

}; 


struct sock5req2 

char Ver; 

char Cmd; 

char Rsv; 

char Atyp; 

char other[1]; 

}; 


struct sock5ans2 

char Ver; 

char Rep; 

char Rsv; 

char Atyp; 

char other[1]; 

}; 


struct authreq 

char Ver; 

char Ulen; 

char Name[255]; 

char PLen; 

char Pass[255]; 

}; 


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[100]; 

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[600]; 

struct sock5req1 *m_proxyreq1; 

m_proxyreq1 = (struct sock5req1 *)buff; 

m_proxyreq1->Ver = 5; 

m_proxyreq1->nMethods = 2; 

m_proxyreq1->Methods[0] = 0; 

m_proxyreq1->Methods[1] = 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[600]; 

sprintf( buff, "%s%s:%d%s","CONNECT ",GetServerHostName(),GetPort()," HTTP/1.1/r/nUser-Agent: MyApp/0.1/r/n/r/n"); 

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连接,如果在内部网侦听或通过UDP协议发送信息,可查阅RFC1829等文档资料。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!如果您想在使用 QWebEngineView 进行网络请求时使用 SOCKS 代理,可以按照以下步骤进行设置: 1. 首先,您需要在项目中添加 QtNetwork 模块的依赖。在您的 .pro 文件中添加以下行: ``` QT += network ``` 2. 在代码中创建一个 QNetworkProxy 对象,并将其设置为 QWebEngineProfile 的代理。这将确保 QWebEngineView 使用指定的代理进行网络请求。下面是一个示例: ```cpp #include <QApplication> #include <QWebEngineProfile> #include <QNetworkProxy> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建一个 QNetworkProxy 对象 QNetworkProxy proxy; proxy.setType(QNetworkProxy::Socks5Proxy); // 设置代理类型为 SOCKS5 proxy.setHostName("127.0.0.1"); // 设置代理服务器的主机名 proxy.setPort(1080); // 设置代理服务器的端口号 // 获取默认的 QWebEngineProfile 对象并设置代理 QWebEngineProfile *profile = QWebEngineProfile::defaultProfile(); profile->setHttpProxy(proxy); profile->setHttpsProxy(proxy); // 创建并显示 QWebEngineView QWebEngineView view; view.load(QUrl("https://www.example.com")); view.show(); return app.exec(); } ``` 请注意,上述示例中的代理配置仅适用于 SOCKS5 代理,如果您使用其他类型的代理,请相应更改 setType() 方法的参数。 3. 编译并运行您的应用程序,此时 QWebEngineView 应该会通过指定的 SOCKS 代理进行网络请求。 希望这能帮到您!如果您有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值