«August 2025»
12
3456789
10111213141516
17181920212223
24252627282930
31


公告

本站技术贴除标明为“原创”的之外,其余均为网上转载,文中我会尽量保留原作者姓名,若有侵权请与我联系,我将第一时间做出修改。谢谢!

             ——既瑜


天气预报(南京)


我的分类(专题)

首页(183)
【趣味文摘】(22)
【五子连珠】(13)
【技术文档】(136)
【电脑技术】(6)
【疑难问题】(1)
【我的心情】(5)


最新日志
花语(中英文对照版)
各种花的花语
NTFS格式的7个精彩问答(pconli
童言无忌,有趣得一蹋
给MM修电脑的三个步骤[转载]
J2EE 面试题综合
JAVA编程规则
[转] P2P之UDP穿透NAT的原理与
[转]词法分析器
文件加密技术
一个让人发狂的PI求解C程序
[转]直线生成算法之DDA
[转]利用内核对象----互斥量实现应用
[转]如何正确的计算文件收发进度
双机调试VC程序
[转]分治法优化大整数乘法 C++实现
浮点数值的内存结构
[转]双链表实现大整数的加法与乘法[VC
拜占廷将军问题[转]
某人的挂QQ的程序源代码,虽然没用了,拿

最新回复
回复:vc中的CString的操作
回复:[转]分治法优化大整数乘法 C++
回复:[转]分治法优化大整数乘法 C++
回复:花语(中英文对照版)
回复:基本排序算法比较与选择[转载]
回复:c++中强制类型转换操作符小结
回复:c++中强制类型转换操作符小结
何必那么执着于是大头猫还是愤怒的小鸟,淡
回复:浮点数值的内存结构
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:32位位图到24位位图的转换
dren, ages 16 and 20
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:各种花的花语

留言板
签写新留言

不是0-1背包喔
桂花的花语``
谢谢
提议
提议

统计
blog名称:★既瑜★
日志总数:183
评论数量:636
留言数量:-25
访问次数:1408907
建立时间:2005年3月12日

链接


http://www.nju.edu.cn
http://bbs.nju.edu.cn 
http://www.t7-online.com
http://www.csdn.net
http://www.91f.net
http://www.crsky.com
我的MSN BLOG 

联系我

  OICQ:215768265
  njucs2001@hotmail.com
  erichoo1982@gmail.com

 

W3CHINA Blog首页    管理页面    写新日志    退出


[【技术文档】]穿透代理服务器编程
既瑜(224499) 发表于 2005/3/18 20:05:52

在网络程序设计过程中,我们经常要与各种类型的代理服务器打交道,比如在企业内部网 通过代理去访问Internet网上的服务器等等,一般代理服务器支持几种常见的代理协议标 准,如Socks4,Socks5,Http代理,其中Socks5需要用户验证,代理相对复杂。我在查阅RF C文档和相关资料后,特总结一些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等文档资料 。

阅读全文(1637) | 回复(0) | 编辑 | 精华


发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)

站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.047 second(s), page refreshed 144781752 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号