aardio 官方社区

 找回密码
 注册会员

QQ登录

只需一步,快速开始

搜索
查看: 94142|回复: 40

HTTP请求模型、头信息参考、aardio开发实例

 火.. [复制链接]

5

主题

429

回帖

2420

积分

五级会员

积分
2420
发表于 2012-4-1 20:27:03 | 显示全部楼层 |阅读模式
一、连接至Web服务器

一个客户端应用(如Web浏览器)打开到Web服务器的HTTP端口的一个套接字(缺省为80)。
例如:http://bbs.aardio.com:80/index.html
在aardio中,这将等同于代码:
  1. import wsock.tcp.client;
  2. var tcp = wsock.tcp.client()
  3. tcp.connect("bbs.aardio.com",80)
复制代码
二、发送HTTP请求

通过连接,客户端写一个ASCII文本请求行,
后跟0或多个HTTP头标,一个空行和实现请求的任意数据。
一个请求由四个部分组成:请求行、请求头标、空行和请求数据

1.请求行:请求行由三个标记组成:请求方法、请求URI和HTTP版本,它们用空格分隔。
例如:GET /index.html HTTP/1.1

HTTP规范定义了8种可能的请求方法:
GET            检索URI中标识资源的一个简单请求
HEAD            与GET方法相同,服务器只返回状态行和头标,并不返回请求文档
POST            服务器接受被写入客户端输出流中的数据的请求
PUT            服务器保存请求数据作为指定URI新内容的请求
DELETE            服务器删除URI中命名的资源的请求
OPTIONS        关于服务器支持的请求方法信息的请求
TRACE            Web服务器反馈Http请求和其头标的请求
CONNECT        已文档化但当前未实现的一个方法,预留做隧道处理

2.请求头标:由关键字/值对组成,每行一对,关键字和值用冒号(:)分隔。
请求头标通知服务器有关于客户端的功能和标识,典型的请求头标有:
User-Agent        客户端厂家和版本
Accept            客户端可识别的内容类型列表
Content-Length    附加到请求的数据字节数
3.空行:最后一个请求头标之后是一个空行,发送回车符和退行,通知服务器以下不再有头标。
4.请求数据:使用POST传送数据,最常使用的是Content-Type和Content-Length头标。

下面使用 aardio模拟上面的过程:

  1. import wsock.tcp.client;
  2. var tcp = wsock.tcp.client()
  3. tcp.connect("bbs.aardio.com",80)

  4. sendData =/***********
  5. HEAD /  HTTP/1.1
  6. Host: bbs.aardio.com
  7. User-Agent: Mozilla/5.0  
  8. Accept: */*;   
  9. ***********/

  10. tcp.write( sendData + '\r\n\r\n' );
  11. headers = tcp.readTo('\r\n\r\n');//HTTP头以两个回车换行结束
  12. tcp.close() ;

  13. import console;
  14. console.log( headers  )
  15. console.pause();
复制代码
三、服务端接受请求并返回HTTP响应

Web服务器解析请求,定位指定资源。服务器将资源副本写至套接字,在此处由客户端读取。
一个响应由四个部分组成;状态行、响应头标、空行、响应数据

1.状态行:状态行由三个标记组成:HTTP版本、响应代码和响应描述。
HTTP版本:向客户端指明其可理解的最高版本。
响应代码:3位的数字代码,指出请求的成功或失败,如果失败则指出原因。
响应描述:为响应代码的可读性解释。
例如:HTTP/1.1 200 OK
HTTP响应代码:
1xx:信息,请求收到,继续处理
2xx:成功,行为被成功地接受、理解和采纳
3xx:重定向,为了完成请求,必须进一步执行的动作
4xx:客户端错误
5xx:服务端错误


2.响应头标:像请求头标一样,它们指出服务器的功能,标识出响应数据的细节。
3.空行:最后一个响应头标之后是一个空行,发送回车符和退行,表明服务器以下不再有头标。
4.响应数据:HTML文档和图像等,也就是HTML本身。

下面使用aardio模拟实现一个完整的HTTP请求响应过程:

  1. import wsock.tcp.client;
  2. var tcp = wsock.tcp.client();
  3. tcp.connect("bbs.aardio.com",80);

  4. var sendData =/***********
  5. GET /  HTTP/1.1
  6. Host: bbs.aardio.com
  7. Connection: close
  8. User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US)
  9. Cache-Control: max-age=0
  10. Accept: application/xml,application/xhtml+xml,text/html;q=0.9,text/plain,image/png,*/*;  
  11. Accept-Language: zh-CN,zh;
  12. Accept-Charset: GBK,utf-8;  
  13. ***********/
  14. tcp.write( sendData + '\r\n\r\n' )

  15. import console;
  16. for(str,size in tcp.eachRead() ){
  17.         console.log(str);
  18.         console.more( 10 );
  19. }

  20. tcp.close();
  21. console.pause();
复制代码

四、服务器关闭连接,浏览器解析响应

1.浏览器首先解析状态行,查看表明请求是否成功的状态代码。
2.然后解析每一个响应头标,头标告知以下为若干字节的HTML。
3.读取响应数据HTML,根据HTML的语法和语义对其进行格式化,并在浏览器窗口中显示它。
4.一个HTML文档可能包含其它需要被载入的资源引用,浏览器识别这些引用,对其它的资源再进行额外的请求,此过程循环多次。
五、无状态连接

HTTP模型是无状态的,表明在处理一个请求时,Web服务器并不记住来自同一客户端的请求。

六、实例

1.浏览器发出请求
GET /index.html HTTP/1.1

服务器返回响应
HTTP /1.1 200 OK
Date: Apr 11 2006 15:32:08 GMT
Server: Apache/2.0.46(win32)
Content-Length: 119
Content-Type: text/html
<HTML>
<HEAD>
<LINK REL=”stylesheet” HREF=”index.css”>
</HEAD>
<BODY>
<IMG SRC=”image/logo.png”>
</BODY>
</HTML>

2.浏览器发出请求

GET /index.css HTTP/1.1
服务器返回响应
HTTP /1.1 200 OK
Date: Apr 11 2006 15:32:08 GMT
Server: Apache/2.0.46(win32)
Connection: Keep-alive, close
Content-Length: 70
Content-Type: text/plane
h3{
font-size:20px;
font-weight:bold;
color:#005A9C;
}

3.浏览器发出请求
GET image/logo.png HTTP/1.1
服务器返回响应
HTTP /1.1 200 OK
Date: Apr 11 2006 15:32:08 GMT
Server: Apache/2.0.46(win32)
Connection: Keep-alive, close
Content-Length: 1280
Content-Type: text/plane
{Binary image data follows}

(附录)

1.HTTP规范:Internet工程制定组织(IETF)发布的RFC指定Internet标准,这些RFC被Internet研究发展机构广泛接受。因为它们是标准文档,故一般用正规语言编写,如立法文标一样。
2.RFC:RFC一旦被提出,就被编号且不会再改变,当一个标准被修改时,则给出一个新的RFC。作为标准,RFC在Internet上被广泛采用。
3.HTTP的几个重要RFC:
RFC1945    HTTP 1.0 描述
RFC2068    HTTP 1.1 初步描述
RFC2616    HTTP 1.1 标准
4.资源标识符URI(Uniform Resource Identifter,URI)


HTTP参考

一、HTTP码应码

响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行。
响应码分五种类型,由它们的第一位数字表示:
1.1xx:信息,请求收到,继续处理
2.2xx:成功,行为被成功地接受、理解和采纳
3.3xx:重定向,为了完成请求,必须进一步执行的动作
4.4xx:客户端错误,请求包含语法错误或者请求无法实现
5.5xx:服务器错误,服务器不能实现一种明显无效的请求
下表显示每个响应码及其含义(状态码描述取自aardio标准库 inet.httpStatusCode):
inet.httpStatusCode = {
        [100]="提示/客户端应继续请求";
        [101]="提示/切换协议";
        [200]="已成功";
        [201]="已成功/创建资源";
        [202]="已成功/接受请求";
        [203]="已成功/非权威信息";
        [204]="已成功/无内容";
        [205]="已成功/重置内容";
        [206]="已成功/断点续传部分内容";
        [300]="重定向/多项选择";
        [301]="重定向/永久移动地址";
        [302]="重定向/已找到地址";
        [303]="重定向/参见其他";
        [304]="重定向/未修改使用缓存";
        [305]="重定向/需使用代理";
        [306]="重定向/未使用";
        [307]="重定向/临时";
        [400]="客户端错误/错误请求";
        [401]="客户端错误/未授权";
        [402]="客户端错误/需付费";
        [403]="客户端错误/禁止访问";
        [404]="客户端错误/未找到";
        [405]="客户端错误/错误的指令动词";
        [406]="客户端错误/拒绝请求";
        [407]="客户端错误/要求代理认证";
        [408]="客户端错误/请求超时";
        [409]="客户端错误/冲突";
        [410]="客户端错误/已删除";
        [411]="客户端错误/未指定长度";
        [412]="客户端错误/未满足前提条件";
        [413]="客户端错误/请求实体太大";
        [414]="客户端错误/请求地址太长";
        [415]="客户端错误/不支持的媒体类型";
        [416]="客户端错误/错误的字节区段";
        [417]="客户端错误/预期结果失败";
        [500]="服务器错误/内部错误";
        [501]="服务器错误/未实现";
        [502]="服务器错误/网关故障";
        [503]="服务器错误/无效服务";
        [504]="服务器错误/网关超时";
        [505]="服务器错误/不支持的HTTP协议版本"
}

二、HTTP头标

HTTP(HyperTextTransferProtocol)即超文本传输协议,目前网页传输的的通用协议。HTTP协议采用了请求/响应模型,浏览器或其他客户端发出请求,服务器给与响应。就整个网络资源传输而言,包括message-header和message-body两部分。首先传递message- header,即http header消息 。http header 消息通常被分为4个部分:general  header, request header, response header, entity header。但是这种分法就理解而言,感觉界限不太明确。根据维基百科对http header内容的组织形式,大体分为Request和Response两部分。


Requests部分
Header解释示例
Accept指定客户端能够接收的内容类型Accept: text/plain, text/html
Accept-Charset浏览器可以接受的字符编码集。Accept-Charset: iso-8859-5
Accept-Encoding指定浏览器可以支持的web服务器返回内容压缩编码类型。Accept-Encoding: compress, gzip
Accept-Language浏览器可接受的语言Accept-Language: en,zh
Accept-Ranges可以请求网页实体的一个或者多个子范围字段Accept-Ranges: bytes
AuthorizationHTTP授权的授权证书Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Cache-Control指定请求和响应遵循的缓存机制Cache-Control: no-cache
Connection表示是否需要持久连接。(HTTP 1.1默认进行持久连接)Connection: close
CookieHTTP请求发送时,会把保存在该请求域名下的所有cookie值一起发送给web服务器。Cookie: $Version=1; Skin=new;
Content-Length请求的内容长度Content-Length: 348
Content-Type请求的与实体对应的MIME信息Content-Type: application/x-www-form-urlencoded
Date请求发送的日期和时间Date: Tue, 15 Nov 2010 08:12:31 GMT
Expect请求的特定的服务器行为Expect: 100-continue
From发出请求的用户的EmailFrom: user@email.com
Host指定请求的服务器的域名和端口号Host: www.aardio.com
If-Match只有请求内容与实体相匹配才有效If-Match: “737060cd8c284d8af7ad3082f209582d”
If-Modified-Since如果请求的部分在指定时间之后被修改则请求成功,未被修改则返回304代码If-Modified-Since: Sat, 29 Oct 2010 19:43:31 GMT
If-None-Match如果内容未改变返回304代码,参数为服务器先前发送的Etag,与服务器回应的Etag比较判断是否改变If-None-Match: “737060cd8c284d8af7ad3082f209582d”
If-Range如果实体未改变,服务器发送客户端丢失的部分,否则发送整个实体。参数也为EtagIf-Range: “737060cd8c284d8af7ad3082f209582d”
If-Unmodified-Since只在实体在指定时间之后未被修改才请求成功If-Unmodified-Since: Sat, 29 Oct 2010 19:43:31 GMT
Max-Forwards限制信息通过代理和网关传送的时间Max-Forwards: 10
Pragma用来包含实现特定的指令Pragma: no-cache
Proxy-Authorization连接到代理的授权证书Proxy-Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Range只请求实体的一部分,指定范围Range: bytes=500-999
Referer先前网页的地址,当前请求网页紧随其后,即来路Referer: http://www.aardio.com/archives/71.html
TE客户端愿意接受的传输编码,并通知服务器接受接受尾加头信息TE: trailers,deflate;q=0.5
Upgrade向服务器指定某种传输协议以便服务器进行转换(如果支持)Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11
User-AgentUser-Agent的内容包含发出请求的用户信息User-Agent: Mozilla/5.0 (Linux; X11)
Via通知中间网关或代理服务器地址,通信协议Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)
Warning关于消息实体的警告信息Warn: 199 Miscellaneous warning

Responses 部分
Header解释示例
Accept-Ranges表明服务器是否支持指定范围请求及哪种类型的分段请求Accept-Ranges: bytes
Age从原始服务器到代理缓存形成的估算时间(以秒计,非负)Age: 12
Allow对某网络资源的有效的请求行为,不允许则返回405Allow: GET, HEAD
Cache-Control告诉所有的缓存机制是否可以缓存及哪种类型Cache-Control: no-cache
Content-Encodingweb服务器支持的返回内容压缩编码类型。Content-Encoding: gzip
Content-Language响应体的语言Content-Language: en,zh
Content-Length响应体的长度Content-Length: 348
Content-Location请求资源可替代的备用的另一地址Content-Location: /index.htm
Content-MD5返回资源的MD5校验值Content-MD5: Q2hlY2sgSW50ZWdyaXR5IQ==
Content-Range在整个返回体中本部分的字节位置Content-Range: bytes 21010-47021/47022
Content-Type返回内容的MIME类型Content-Type: text/html; charset=utf-8
Date原始服务器消息发出的时间Date: Tue, 15 Nov 2010 08:12:31 GMT
ETag请求变量的实体标签的当前值ETag: “737060cd8c284d8af7ad3082f209582d”
Expires响应过期的日期和时间Expires: Thu, 01 Dec 2010 16:00:00 GMT
Last-Modified请求资源的最后修改时间Last-Modified: Tue, 15 Nov 2010 12:45:26 GMT
Location用来重定向接收方到非请求URL的位置来完成请求或标识新的资源Location: http://www.aardio.com/archives/94.html
Pragma包括实现特定的指令,它可应用到响应链上的任何接收方Pragma: no-cache
Proxy-Authenticate它指出认证方案和可应用到代理的该URL上的参数Proxy-Authenticate: Basic
refresh应用于重定向或一个新的资源被创造,在5秒之后重定向(由网景提出,被大部分浏览器支持)



Refresh: 5; url=
http://www.aardio.com/archives/94.html
Retry-After如果实体暂时不可取,通知客户端在指定时间之后再次尝试Retry-After: 120
Serverweb服务器软件名称Server: Apache/1.3.27 (Unix) (Red-Hat/Linux)
Set-Cookie设置Http CookieSet-Cookie: UserID=JohnDoe; Max-Age=3600; Version=1
Trailer指出头域在分块传输编码的尾部存在Trailer: Max-Forwards
Transfer-Encoding文件传输编码Transfer-Encoding:chunked
Vary告诉下游代理是使用缓存响应还是从原始服务器请求Vary: *
Via告知代理客户端响应是通过哪里发送的Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)
Warning警告实体可能存在的问题Warning: 199 Miscellaneous warning
WWW-Authenticate表明客户端请求实体应该使用的授权方案WWW-Authenticate: Basic


头标由主键/值对组成。它们描述客户端或者服务器的属性、被传输的资源以及应该实现连接。

四种不同类型的头标:
1.通用头标:即可用于请求,也可用于响应,是作为一个整体而不是特定资源与事务相关联。
2.请求头标:允许客户端传递关于自身的信息和希望的响应形式。
3.响应头标:服务器和于传递自身信息的响应。
4.实体头标:定义被传送资源的信息。即可用于请求,也可用于响应。

头标格式:<name>:<value><CRLF>
下表描述在HTTP/1.1中用到的头标
Accept 定义客户端可以处理的媒体类型,按优先级排序;
在一个以逗号为分隔的列表中,可以定义多种类型和使用通配符。例如:Accept: image/jpeg,image/png,*/*
Accept-Charset        定义客户端可以处理的字符集,按优先级排序;
在一个以逗号为分隔的列表中,可以定义多种类型和使用通配符。例如:Accept-Charset: iso-8859-1,*,utf-8

Accept-Encoding        定义客户端可以理解的编码机制。例如:Accept-Encoding:gzip,compress
请用此头标可以向服务器请求压缩后的数据(需要服务器支持),下面是使用aardio模拟的一个实例:
//gzip解压缩
import zlib;//只要导入 zlib 库,inet.http 就支持 gzip 自动解压

import inet.whttp;

var http = inet.whttp();
var str = http.get("http://eu.httpbin.org/gzip","Accept-Encoding:gzip")

import console;
console.log(str);
console.pause();


Accept-Language    定义客户端乐于接受的自然语言列表。例如:Accept-Language: en,de
Accept-Ranges        一个响应头标,它允许服务器指明:将在给定的偏移和长度处,为资源组成部分的接受请求。
该头标的值被理解为请求范围的度量单位。例如Accept-Ranges: bytes或Accept-Ranges: none
Age 允许服务器规定自服务器生成该响应以来所经过的时间长度,以秒为单位。
该头标主要用于缓存响应。例如:Age: 30
Allow 一个响应头标,它定义一个由位于请求URI中的次源所支持的HTTP方法列表。例如:Allow: GET,PUT
aUTHORIZATION 一个响应头标,用于定义访问一种资源所必需的授权(域和被编码的用户ID与口令)。
例如:Authorization: Basic YXV0aG9yOnBoaWw=
Cache-Control 一个用于定义缓存指令的通用头标。例如:Cache-Control: max-age=30
Connection 一个用于表明是否保存socket连接为开放的通用头标。例如:Connection: close或Connection: keep-alive
Content-Base 一种定义基本URI的实体头标,为了在实体范围内解析相对URLs。
如果没有定义Content-Base头标解析相对URLs,使用Content-Location URI(存在且绝对)或使用URI请求。
例如:Content-Base: Http://www.aardio.com
Content-Encoding 一种介质类型修饰符,标明一个实体是如何编码的。例如:Content-Encoding: zip
Content-Language 用于指定在输入流中数据的自然语言类型。例如:Content-Language: en
Content-Length        指定包含于请求或响应中数据的字节长度。例如:Content-Length:382
Content-Location        指定包含于请求或响应中的资源定位(URI)。
如果是一绝。对URL它也作为被解析实体的相对URL的出发点。
例如:Content-Location: http://www.aardio.com/news
Content-MD5        实体的一种MD5摘要,用作校验和。
发送方和接受方都计算MD5摘要,接受方将其计算的值与此头标中传递的值进行比较。
例如:Content-MD5: <base64 of 128 MD5 digest>
Content-Range        随部分实体一同发送;标明被插入字节的低位与高位字节偏移,也标明此实体的总长度。
例如:Content-Range: 1001-2000/5000
Contern-Type        标明发送或者接收的实体的MIME类型。例如:Content-Type: text/html
Date            发送HTTP消息的日期。例如:Date: Mon,10PR 18:42:51 GMT
ETag            一种实体头标,它向被发送的资源分派一个唯一的标识符。
对于可以使用多种URL请求的资源,ETag可以用于确定实际被发送的资源是否为同一资源。
例如:ETag: ”208f-419e-30f8dc99″
Expires            指定实体的有效期。例如:Expires: Mon,05 Dec 2008 12:00:00 GMT
Form            一种请求头标,给定控制用户代理的人工用户的电子邮件地址。例如:From: webmaster@aardio.com
Host            被请求资源的主机名。对于使用HTTP/1.1的请求而言,此域是强制性的。例如:Host: www.aardio.com
If-Modified-Since        如果包含了GET请求,导致该请求条件性地依赖于资源上次修改日期。
如果出现了此头标,并且自指定日期以来,此资源已被修改,应该反回一个304响应代码。
例如:If-Modified-Since: Mon,10PR 18:42:51 GMT
If-Match            如果包含于一个请求,指定一个或者多个实体标记。只发送其ETag与列表中标记区配的资源。
例如:If-Match: ”208f-419e-308dc99″
If-None-Match        如果包含一个请求,指定一个或者多个实体标记。资源的ETag不与列表中的任何一个条件匹配,操作才执行。
例如:If-None-Match: ”208f-419e-308dc99″
If-Range            指定资源的一个实体标记,客户端已经拥有此资源的一个拷贝。必须与Range头标一同使用。
如果此实体自上次被客户端检索以来,还不曾修改过,那么服务器只发送指定的范围,否则它将发送整个资源。
例如:Range: byte=0-499<CRLF>If-Range:”208f-419e-30f8dc99″
If-Unmodified-Since    只有自指定的日期以来,被请求的实体还不曾被修改过,才会返回此实体。
例如:If-Unmodified-Since:Mon,10PR 18:42:51 GMT
Last-Modified        指定被请求资源上次被修改的日期和时间。例如:Last-Modified: Mon,10PR 18:42:51 GMT
Location            对于一个已经移动的资源,用于重定向请求者至另一个位置。
与状态编码302(暂时移动)或者301(永久性移动)配合使用。
例如:Location: http://www2.aardio.com/index.jsp
Max-Forwards        一个用于TRACE方法的请求头标,以指定代理或网关的最大数目,该请求通过网关才得以路由。
在通过请求传递之前,代理或网关应该减少此数目。例如:Max-Forwards: 3
Pragma            一个通用头标,它发送实现相关的信息。例如:Pragma: no-cache
Proxy-Authenticate    类似于WWW-Authenticate,便是有意请求只来自请求链(代理)的下一个服务器的认证。
例如:Proxy-Authenticate: Basic realm-admin
Proxy-Proxy-Authorization    类似于授权,但并非有意传递任何比在即时服务器链中更进一步的内容。
例如:Proxy-Proxy-Authorization: Basic YXV0aG9yOnBoaWw=
Public            列表显示服务器所支持的方法集。例如:Public: OPTIONS,MGET,MHEAD,GET,HEAD
Range            指定一种度量单位和一个部分被请求资源的偏移范围。例如:Range: bytes=206-5513
Refener            一种请求头标域,标明产生请求的初始资源。对于HTML表单,它包含此表单的Web页面的地址。
例如:Refener: http://www.aardio.com/news/search.html
Retry-After        一种响应头标域,由服务器与状态编码503(无法提供服务)配合发送,以标明再次请求之前应该等待多长时间。
此时间即可以是一种日期,也可以是一种秒单位。例如:Retry-After: 18
Server            一种标明Web服务器软件及其版本号的头标。例如:Server: Apache/2.0.46(Win32)
Transfer-Encoding    一种通用头标,标明对应被接受方反向的消息体实施变换的类型。例如:Transfer-Encoding: chunked
Upgrade        允许服务器指定一种新的协议或者新的协议版本,与响应编码101(切换协议)配合使用。
例如:Upgrade: HTTP/2.0
User-Agent        定义用于产生请求的软件类型(典型的如Web浏览器)。
例如:User-Agent: Mozilla/4.0(compatible; MSIE 5.5; Windows NT; DigExt)
Vary            一个响应头标,用于表示使用服务器驱动的协商从可用的响应表示中选择响应实体。例如:Vary: *
Via            一个包含所有中间主机和协议的通用头标,用于满足请求。例如:Via: 1.0 fred.com, 1.1 wilma.com
Warning            用于提供关于响应状态补充信息的响应头标。例如:Warning: 99 www.aardio.com Piano needs tuning
www-Authenticate    一个提示用户代理提供用户名和口令的响应头标,与状态编码401(未授权)配合使用。响应一个授权头标。
例如:www-Authenticate: Basic realm=zxm.mgmt

aardio HTTP开发实例:
  1. import wsock.tcp.client;
  2. var tcp = wsock.tcp.client()
  3. tcp.connect("bbs.aardio.com",80)

  4. sendData =/***********
  5. GET /  HTTP/1.1
  6. Host: bbs.aardio.com
  7. Connection: close
  8. User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US)
  9. Cache-Control: max-age=0
  10. Accept: application/xml,application/xhtml+xml,text/html;q=0.9,text/plain,image/png,*/*;  
  11. Accept-Language: zh-CN,zh;
  12. Accept-Charset: GBK,utf-8;  
  13. ***********/
  14. tcp.write( sendData + '\r\n\r\n' );

  15. import console;
  16. for(str,size in tcp.eachRead() ){
  17.     console.log( str );
  18. }

  19. tcp.close();
  20. console.pause();
复制代码
当然, aardio已经将上面的代码封装为傻瓜化的函数。
仅需要一句代码就可以下载指定的文件
  1. var data = inet.http().get("http://bbs.aardio.com")
复制代码
inet.http 的用法与 inet.whttp 的用法完全一样,
aardio很多支持库用法都非常接近, 所以学习 aardio 获得的回报很棒.

inet.http 用于一般的http操作,与客户端浏览器更接近(虽然没有界面)
例如他可以更好的支持持久化cookie.

inet.whttp 则拥有更好的性能和稳定性,可以用于长久运行的NT服务程序开发
关于这一点,可以参考微软MSDN,aardio中的inet.http库也就是WINInet函数的封装,
而 inet.whttp 则是 WinHTTP 接口的封装

评分

参与人数 3 +80 收起 理由
zjutsxj + 10 很给力!
air_fans + 40 很给力!
zhuyuruicu + 30 精髓!

查看全部评分

5

主题

429

回帖

2420

积分

五级会员

积分
2420
 楼主| 发表于 2012-4-1 20:30:51 | 显示全部楼层
import fsys;
import inet.http
import inet.httpFile;

fsys.createDir(
"~/download/lib")
var remoteFile = inet.httpFile(
   
"http://oss.aardio.com/aardio/lib/tcc.cab" ,"~/download/lib/tcc.cab"
    )
   
import console   
console.log(
"文件在上次下载后是否修改过?",remoteFile.isModified() )

remoteFile.onReceiveBegin =
function(statusCode,contentLength,fileSize){
   
if( statusCode == 206/*断点续传*/ ){
        console.log(
"正在断点续传")
    }
   
elseif(fileSize){
        console.log(
"正在重新下载")
    }
   
    console.log(
"未下载长度",contentLength,"已下载长度",fileSize, "HTTP状态码", statusCode )
}

remoteFile.onReceive =
function(str,size,contentLength){
    console.log(
"总长度",contentLength , "下载", size )
   
//return false; //返回false停止下载
}

//下载文件
var ok,err,fileSize = remoteFile.download()

console.log( ok,fileSize,err,inet.lastResponse() )

5

主题

429

回帖

2420

积分

五级会员

积分
2420
 楼主| 发表于 2012-4-1 20:32:38 | 显示全部楼层
上传大文件时通常要显示上传进度,直接用POST可能不方便,所以需要用到文件流的方式上传:
import process
import inet.http

http = inet.http(  );
http.beginRequest(
"http://test.aardio.com/aardio/test/post" );

//循环上传
http.beginSendData(1000)  
for(i=1;1000;1){
    http.writeData(
" " )
}
http.endSendData()

//循环下载
import console
for(str,size in http.eachRead() ){
    console.log( str );  
}

console.log(
"ok")
使用标准库中的 web.rest.client 上传文件更简单一些,请参考文章:使用 web.rest 调用 REST API

示例:
restClient.sendFile( "上传文件路径"
    ,
function(str,sendSize,contentLength){
        ..console.log(
"正在上传",sendSize,contentLength);
    }
);

//在后面再简单的调用API就可以了,例如
restApi.upload()

5

主题

429

回帖

2420

积分

五级会员

积分
2420
 楼主| 发表于 2012-4-1 20:36:33 | 显示全部楼层
//FTP文件流读写
import console;

import inet.ftp;

ftp = inet.ftp(
"服务器IP","用户名","密码");
if(!ftp){
    ..console.log(
"请输入正确的服务器参数");
   
return;
}

//显示当前目录
console.log( ftp.getCurDir() )

//关闭服务器UTF8编码
ftp.command("OPTS UTF8 off")

file = ftp.open(
"/目录/文件名.txt","wb")

//支持文件流方式上传数据,使用循环即可控制上传进度
file.write("写数据","写更多数据",'\r\n')
file.write(
"写数据","写更多数据",'\r\n')

ftp.close()


附注:以上所有代码来自aardio标准库,及范例。
无论是 HTTP,WHTTP,FTP, 底层用法都非常复杂,实现控制自如的效果都非常困难,而用各函数的用法也各自不同,

aardio将这一切都进行了封装,并进行简化,提供了非常简单,并几近一致的接口
最重要的是,这些都完全重用了系统提供的API,不需要第三方库,所以你可以自由的使用上面的功能,而且你的程序将会非常小。而对于互联网桌面软件,size则是必须重视的一个开发重点。

8

主题

56

回帖

464

积分

二级会员

积分
464
发表于 2012-4-1 21:12:34 | 显示全部楼层

难得的好资料!!!Mark~
感谢楼主~!~!~!

52

主题

1270

回帖

7276

积分

荣誉会员

积分
7276
发表于 2012-4-1 21:15:07 | 显示全部楼层
辛苦整理了,感谢~

0

主题

4

回帖

96

积分

一级会员

积分
96
发表于 2012-4-1 21:42:35 | 显示全部楼层
感谢楼主!!!!!!

117

主题

1103

回帖

6572

积分

六级会员

积分
6572
发表于 2012-4-2 01:13:27 | 显示全部楼层
//读取返回数据
for(str,size in var data = whttp.eachRead() ){
    ..console.log( str )
}

10

主题

40

回帖

553

积分

三级会员

积分
553
发表于 2012-4-2 05:38:58 | 显示全部楼层
强帖,楼主辛苦了,果断收藏

36

主题

135

回帖

1102

积分

四级会员

积分
1102
发表于 2012-4-2 08:52:14 | 显示全部楼层
好贴,从流程和实现方法做了整理

57

主题

199

回帖

1431

积分

四级会员

积分
1431
发表于 2012-4-2 12:22:55 | 显示全部楼层
好帖子了。

48

主题

542

回帖

3328

积分

五级会员

积分
3328
发表于 2012-4-2 12:25:26 | 显示全部楼层
支持神码

4

主题

146

回帖

862

积分

三级会员

积分
862
发表于 2012-4-2 13:12:34 | 显示全部楼层
崇拜中....

5

主题

118

回帖

1483

积分

四级会员

积分
1483
发表于 2012-4-2 13:40:47 | 显示全部楼层
有很强的阅读性和实用性

5

主题

58

回帖

753

积分

荣誉会员

积分
753
发表于 2012-4-4 00:04:20 | 显示全部楼层
辛苦啦!非常好指导贴!

7

主题

293

回帖

1900

积分

新手入门

积分
1900
QQ
发表于 2012-4-4 09:06:27 | 显示全部楼层
收藏学习,楼主辛苦了!

2

主题

18

回帖

171

积分

一级会员

积分
171
发表于 2012-4-11 00:38:09 来自手机 | 显示全部楼层
Mark下,好好学习

0

主题

4

回帖

35

积分

新手入门

积分
35
发表于 2012-5-13 23:59:33 | 显示全部楼层
好东西,收藏下

1

主题

7

回帖

51

积分

一级会员

积分
51
发表于 2012-5-14 22:12:45 | 显示全部楼层
请问有没有HTTPS的?
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

手机版|未经许可严禁引用或转载本站文章|aardio.com|aardio 官方社区 ( 皖ICP备09012014号 )

GMT+8, 2025-1-13 15:17 , Processed in 0.082238 second(s), 26 queries .

Powered by Discuz! X3.5

Copyright © 2001-2024 Tencent Cloud.

快速回复 返回顶部 返回列表