代理穿透技术Word文件下载.docx

上传人:b****6 文档编号:18034988 上传时间:2022-12-13 格式:DOCX 页数:42 大小:39.60KB
下载 相关 举报
代理穿透技术Word文件下载.docx_第1页
第1页 / 共42页
代理穿透技术Word文件下载.docx_第2页
第2页 / 共42页
代理穿透技术Word文件下载.docx_第3页
第3页 / 共42页
代理穿透技术Word文件下载.docx_第4页
第4页 / 共42页
代理穿透技术Word文件下载.docx_第5页
第5页 / 共42页
点击查看更多>>
下载资源
资源描述

代理穿透技术Word文件下载.docx

《代理穿透技术Word文件下载.docx》由会员分享,可在线阅读,更多相关《代理穿透技术Word文件下载.docx(42页珍藏版)》请在冰豆网上搜索。

代理穿透技术Word文件下载.docx

NULL,NULL);

pHttpFile=pConnection->

OpenRequest("

GET"

szObject, 

NULL,0,NULL,NULL, 

INTERNET_FLAG_KEEP_CONNECTION);

//hereforproxy//这里设置代理服务器和端口、用户名和密码

INTERNET_PROXY_INFOproxyinfo;

proxyinfo.dwAccessType=INTERNET_OPEN_TYPE_PROXY;

proxyinfo.lpszProxy=strProxyList;

proxyinfo.lpszProxyBypass=NULL;

mysession.SetOption(INTERNET_OPTION_PROXY,(LPVOID)&

proxyinfo,sizeof(INTERNET_PROXY_INFO));

pHttpFile->

SetOption(INTERNET_OPTION_PROXY_USERNAME,strUsername,strlen(strUsername)+1);

SetOption(INTERNET_OPTION_PROXY_PASSWORD,strPassword,strlen(strPassword)+1);

SendRequest(NULL);

//输出string信息分行放到m_SiteInfo

CStringmyData;

while(pHttpFile->

ReadString(myData))

{

strContent=strContent+"

\r\n"

;

strContent+=myData;

}

//DWORDnFileSize=pHttpFile->

GetLength();

//LPSTRrbuf=szContent.GetBuffer(nFileSize);

//UINTuBytesRead=pHttpFile->

Read(rbuf,nFileSize);

//szContent.ReleaseBuffer();

Close();

deletepHttpFile;

pConnection->

deletepConnection;

mysession.Close();

returnstrContent;

内容:

以下内容是根据我在写远程控制工具时的工作日记整理而成的,一些方法思路是借鉴了前辈的,在此感谢,同时有一点心得,拿出来与大家分享,希望对大家有用。

正文:

1、现状简介

当今大型机构、企业为了保障网络安全、实现统一的安全管理,多采用域控、代理、网关等相关的手段,因此对于这些环境下的网络通信必然会面临代理穿透的问题。

代理软件主要用于网页浏览、下载文件、邮件收发等多种用途。

常见的代理类型有:

FTP

HTTP

HTTPS

SOCKS

Gropher

其中最常用的代理主要有Http、Https和Socks,以下将以http为例说明代理穿透技术。

2、HTTP代理穿透

2.1HTTPCONNECT

HTTP代理服务器中能够提供一种HTTPCONNECT代理服务,能够允许用户建立TCP连接到任何端口。

进一步讲,这种代理不仅可用于HTTP,还包括FTP、IRC、RM流服务等,甚至扫描、攻击。

通过CONNECT方法穿透代理的实现步骤为:

connect代理服务器的代理端口(如:

8080);

如果成功返回就可以按照正常的Socket进行通讯。

注:

ISA防火墙会默认封阻SSL端口以外的其它connect端口,以防被人滥用作扫描,攻击或发送垃圾邮件。

因此穿透ISA,我们可以connect443端口,然后把443映射为我们需要连接的真正端口。

2.2HTTPGET/POST

HttpGET/POST代理穿透的原理都是通过发送HTTP协议的数据报文来实现,所要传输的数据隐含在HTTP的请求/应答报文中,即网络数据的通信被HTTP协议封装,并且传输的过程遵循HTTP协议本身。

2.2.1HTTP报文格式

(1)请求报文

HTTP请求报文格式为:

请求消息=请求行(实体头信息)CRLF[实体内容]

请求行=方法 URL HTTP版本号 CRLF

方法=GET|HEAD|POST|扩展方法

URL=协议名称+宿主名+目录与文件名

其中"

CRLF"

表示回车换行。

"

请求行"

中的"

方法"

描述了对指定资源执行的动作,常用的方法"

、"

HEAD"

和"

POST"

等3种,它们的含义如表

表1HTTP请求方法

取值描述 

GET从WEB服务器中获取对象,不同类型的对象将获取不同的信息,比如:

·

文件类型对象,获取该文件的内容。

程序类型对象,获取该程序执行的结果。

数据库查询类型对象,获取该查询的结果。

POST从客户端向WEB服务器发送数据。

HEAD要求服务器查找对象的元信息。

实体头信息"

中记载了报文的属性,利用这些信息可以实现客户端与WEB服务器之间的请求或应答,它包括报文的数据类型、压缩方法、语言、长度、压缩方法、最后一次修改时间、数据有效期等信息。

实体内容是报文传送的附加信息,一般供POST请求填写。

以下是GET请求报文的例子:

GET 

http:

//192.168.0.1/test.asp?

value=testinfo 

HTTP/1.1

Accept:

*/*

Accept-Language:

zh-cn

Accept-Encoding:

gzip,deflate

User-Agent:

Mozilla/4.0(compatible;

MSIE6.0;

WindowsNT5.1)

Host:

//192.168.0.1/

Connection:

Keep-Alive

/test.php?

value=testinfo"

是URL信息,语句"

ACCEPT:

*/*"

及其后的语句是"

注意:

在语句"

Connection:

Keep-Alive"

下的空行是必须的。

以下是POST请求报文的例子:

POST/test.cgiHTTP/1.0/*请求行,服务程序为test.cgi*/

/*以下为实体头信息*/

192.168.0.1

Authorization:

Basic<

Base64串>

Content-Length:

<

Content-Length>

/*以下为POST请求的实体信息*/

<

CommandId>

=<

4>

CommandValue>

44>

一般情况下,采用POST报文传送信息的数据存储在"

实体"

部分中。

(2)应答报文

HTTP协议的应答报文格式为:

应答报文=状态行(实体头信息)CRLF[实体内容]

状态行=HTTP版本号 状态码 原因叙述

状态码描述了WEB服务器执行客户机请求的状态信息,其取值含义如表

表2HTTP响应应答码含义

1xx保留 

2xx成功接收 

3xx客户需进一步细化请求 

4xx客户错误 

5xx服务错误 

GET应答报文例子

HTTP/1.1200OK

keep-alive

Date:

Thu,26Jul200714:

00:

02GMT

Server:

Microsoft-IIS/6.0

X-Powered-By:

ASP.NET

190

Content-Type:

text/html

Set-Cookie:

ASPSESSIONIDSAATTCSQ=JOPPKDCAMHHBEOICJPGPBJOB;

path=/

Cache-control:

private

html>

head>

title>

TestPage<

/title>

/head>

body>

fontsize=4>

HelleWorld!

/font>

/body>

/html>

语句"

HTTP/1.1200OK"

中,"

200"

是响应码,"

OK"

是原因描述。

POST应答报文例子

HTTP/1.0200OK/*状态行,应答成功*/

Tue,13Mar200102:

45:

12GMT

Apache/1.3.12(Unix)

close

/*以下为POST应答的实体信息*/

94>

9494>

Result>

0>

一般情况下,POST应答报文的"

部分存储实际传输的信息。

(3)GET和POST数据报文的区别:

GET和POST若用作数据传输时,响应报文的数据存放区别不大,重点在于请求报文中数据的存放。

首先GET方式提交的数据存放在URL中,根据HTTP协议规范,并没有对URL的长度进行限制,但是特定的浏览器和服务器对它有限制,如IE对URL的限制长度为2083字节(2K+35),而其它浏览器(如:

Netscape、FireFox等)理论上没有长度限制,但限制取决于操作系统的支持。

上述的限制是整个URL长度,而不仅仅是你的参数值数据长度。

再者理论上讲POST是没有大小限制的,HTTP协议规范也没有大小限制,但服务器的处理程序的处理能力限制了其大小。

如:

对于ASP程序,Request对象处理每个表单域时存在100K的数据长度限制,但如果使用Request.BinaryRead则没有这个限制。

对于IIS6.0,MS出于安全考虑,加大了限制:

IIS6.0默认ASPPOST数据量最大为200KB,每个表单域限制是100KB;

IIS6.0默认上传文件大小是4MB;

IIS6.0默认最大请求头是16KB;

IIS6.0之前没有这些限制,并且这些参数可以自己设置,具体参见IIS配置文档。

2.2.2GET和POST数据包的构造

(1)伪装GET请求数据包

由于GET请求的数据会附在URL之后(HTTP协议头中),以"

?

分割URL和传输数据,参数之间以"

&

连接。

如果数据是英文字母/数字,则直接发送,如果是空格,转化为"

+"

,如果是中文/其它字符串,则用BASE64加密。

以下是用GET进行数据传输的举例说明:

value=Test 

RequestHTTP/1.1

TestRequest"

就是我们要传输的数据

(2)伪装GET响应数据包

伪转GET响应包比较简单,直接将数据写入HTTP包的实体中,举例如下:

TestResponseInfo

TestResponseInfo"

为响应的数据,当然为了保证较好的安全性可以将真正的数据放入特定的网页标记中如下:

TestResponseInfo!

(3)伪装POST请求数据包

POST把需要传输的数据直接放在HTTP包的实体中,如下:

POST/test.phpHTTP/1.0

RequestCommand>

TestRequest>

RequestCommandValue>

TestRequest"

44"

就是两个请求的数据

(4)伪装POST响应数据包

POST的响应数据与请求数据的存放相似,如下:

HTTP/1.0200OK

ResponseCommand>

TestResponse>

ResponseValue>

其中其中"

TestResponse"

9494"

就是两个响应的数据,而"

此处用作传输结束标志,主要用于大量数据传输时,判断数据包是否是最后一个报文。

2.2.3HTTPGET/POST代理穿透的实现

(1)Sockers实现

Socket实现的Http代理穿透的流程使用关键字"

的过程一样,只是提取数据的时候,需要解析HTTP头部、对应的定制标志或字符,而整个发送过程与普通的Socket网络通讯一样,首先创建socket套接字,然后connect代理服务器和端口,接着send构造的特殊请求数据包,之后就等待接受数据包。

此时还需要做的就是伪造相应的HTTP服务端。

在接受特定的HTTP相应后,解析请求,然后将响应的HTTP头加上特定的响应数据发送回请求端。

(2)WinInet实现

WinInet允许应用程序向Internet服务器增加连接,而不用考虑基本的通信协议,它是程序员可以在较高的层次上建立Internet客户应用程序,提供专业性客户端程序支持,较Winsock有许多的优点。

而此处说的WinInet包括WinInet类、WinInetAPI和MFCWinInet类,其中WinInet类封装了WinInetAPI但不全面,WinInetAPI提供了全部的接口操作,而MFCWinInet类也是封装WinInetAPI,但其为用户提供了更加方便的编程接口。

而WinInet编程从数据包收发的角度上说是和Winsock的实现是等价的,以下以WinInetAPI为例说明请求数据包的发送和接收过程:

//1、建立与服务端的连接,并测试

InternetOpen()

InternetConnect()

InternetAttemptConnect()

//2、添加HTTP请求头和URI

HttpOpenRequest()

HttpAddRequestHeaders()

//3、接受数据

InternetReadFile()

当然使用哪种构造的WinInet可由具体的需求灵活决定。

WinInet只能用户编写Internet的客户端程序,不能用于服务端的编写,因此伪装的服务端还是由Winsock来完成。

2.3总结

本文总结出的HTTP代理的穿透方法主要分为两种方法来实现,即"

CONNECT"

GET/POST"

,前者主要利用代理服务可以建立到指定端口的连接来实现,后者主要的思想就是如何伪装成正常的HTTP程序和服务,并进行网络数据的通信。

另外,HTTPGET/POST代理穿透的实现的前提条件是开启了Http代理服务,再者有时可能还要看具体代理设置的情况,如有的代理服务不允许"

请求。

HTTP代理穿透原理

通过CONNECT方法穿透代理的实现方法为:

CONNECT代理服务器的代理端口(如:

当然在此之前需要先获得代理相关的信息。

如何获取HTTP代理相关信息

程序中是通过读取注册表来获取计算机HTTP代理相关信息的,在注册表的\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet 

Settings键值下就保存着HTTP代理服务器及端口等信息,

根据该键值下的ProxyEnable值可以判断是否有HTTP代理,没有代理的情况下ProxyEnable值为0。

当然一般情况下程序去中访问该键值可能是受限的,所有就需要获取到访问令牌不受限制的UserSid,使用该UserSid去读取HTTP代理信息。

通过HTTP代理代码片段

网络上摘一点代码,原理大概上能实现了的

memset(buff,0,sizeof(buff));

sprintf(buff,"

CONNECT%s:

%dHTTP/1.1\r\nAccept:

*/*\r\nContent-Type:

text/html\r\nProxy-Connection:

Keep-Alive\r\nContent-length:

0\r\n\r\n"

lpszHost,nPort);

send(m_Socket,buff,strlen(buff),0);

........

recv(m_Socket,buff,sizeof(buff),0);

if(strstr(buff,"

200Connection"

)!

=NULL)

returntrue;

//连接成功

此外,如果是GET/POST代理你也可以模拟发post和get包,这个没什么说的,熟悉http协议就可以游刃有余的去编程了!

主要是需要用大白鲨或其他http截包工具去分析调试。

但是,对于客户服务端程序这样就需要额外添加一个中间跳板空间来中转数据。

这本身又是很影响速度的。

而post每次传输的数据还是有点经不起用。

穿透代理服务器编程

发信站:

BBS 

大漠孤烟站 

(Tue 

Apr 

21:

20:

34 

2003)

关键字 

代理服务器、Socks4、Socks5、Http代理 

原作者姓名 

allfresh 

文章原始出处 

正文 

在网络程序设计过程中,我们经常要与各种类型的代理服务器打交道,比如

在企业内部网通过代理去访问Internet网上的服务器等等,一般代理服务器支持几种常见

的代理协议标准,如Socks4,Socks5,Http代理,其中Socks5需要用户验证,代理相对复杂

我在查阅RFC文档和相关资料后,特总结一些TCP协议穿透代理服务器的程序片断,希望

对大家有所帮助。

//使用到的结构 

struct 

sock4req1 

char 

VN;

CD;

unsigned 

short 

Port;

long 

IPAddr;

other[1];

};

sock4ans1 

sock5req1 

Ver;

nMethods;

Methods[255];

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 军事

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1