图解系列--Http

1.URI和URL

1.1.URL

URL是统一资源定位符。URL正是使用 Web 浏览器等访问 Web 页面时需要输入的网页地址。比如,http://hackr.jp/就是 URL。

1.2.URI

统一资源标识符。

URI 用字符串标识某一互联网资源,而URL表示资源的地点(互联网上所处的位置)。可见URL是URI的子集。

上述均是URI。

_1.URI格式

(1).绝对URI

协议方案名:

上述http:指定协议方案名,也可用data:javascript:这类指定数据或脚本程序的方案名。

登录信息:

指定用户名和密码作为从服务器端获取资源时必要的登录信息(身份认证)。此项是可选项。

服务器地址:

使用绝对 URI 必须指定待访问的服务器地址。地址可以是类似hackr.jp这种DNS可解析的名称,或是192.168.1.1这类 IPv4 地址名,还可以是 [0:0:0:0:0:0:0:1] 这样用方括号括起来的IPv6地址名。

服务器端口号:

指定服务器连接的网络端口号。此项也是可选项,若用户省略,则自动使用默认端口号。

带层次的文件路径:

指定服务器上的文件路径来定位特指的资源。这与UNIX系统的文件目录结构相似。

查询字符串:

针对已指定的文件路径内的资源,可以使用查询字符串传入任意参数。此项可选。

片段标识符:

使用片段标识符通常可标记出已获取资源中的子资源(文档内的某个位置)。但在RFC中并没有明确规定其使用方法。该项也为可选项。

2.HTTP

2.1.请求和响应格式

2.1.1.请求

GET请求实例。请求报文是由请求方法、请求 URI、协议版本、可选的请求首部字段和内容实体构成的。

POST请求实例

2.1.2.响应

服务端响应实例。响应报文基本上由协议版本、状态码(表示请求成功或失败的数字代码)、用以解释状态码的原因短语、可选的响应首部字段以及实体主体构成。

2.2.HTTP是不保存状态的协议

协议对于发送过的请求或响应都不做持久化处理。HTTP协议自身不保存之前发送过的请求或响应。

使用HTTP协议,每当有新的请求发送时,就会有对应的新响应产生。协议本身并不保留之前一切的请求或响应报文的信息。

HTTP/1.1虽然是无状态协议,但为了实现期望的保持状态功能,于是引入了Cookie技术。有了Cookie再用HTTP协议通信,就可以管理状态了。

2.3.请求 URI 定位资源

指定URI的方式。

如果不是访问特定资源而是对服务器本身发起请求,可以用一个 * 来代替请求 URI。下面这个例子是查询 HTTP 服务器端支持的 HTTP 方法种类。

2.4.告知服务器意图的HTTP方法

2.4.1.GET

GET方法用来请求访问已被URI识别的资源。

如果请求的资源是文本,那就保持原样返回;如果是像CGI那样的程序,则返回经过执行后的输出结果。

2.4.2.POST

POST方法用来传输实体的主体。

用GET方法也可以传输实体的主体,但一般不用GET方法进行传输,而是用POST方法。

2.4.3.PUT

PUT 方法用来传输文件。实现文件上传到服务端。

要求在请求报文的主体中包含文件内容,然后保存到请求URI指定的位置。

鉴于HTTP/1.1的PUT方法自身不带验证机制,任何人都可以上传文件,存在安全性问题,因此一般的Web网站不使用该方法。

2.4.4.HEAD

HEAD方法和GET方法一样,只是不返回报文主体部分。用于确认URI的有效性及资源更新的日期时间等。

2.4.5.DELETE

DELETE方法用来删除文件。DELETE方法按请求URI删除指定的资源。

HTTP/1.1 的 DELETE 方法本身和 PUT 方法一样不带验证机制,所以一般的 Web 网站也不使用 DELETE 方法。

2.4.6.OPTIONS

OPTIONS 方法用来查询针对请求 URI 指定的资源支持的方法。

2.4.7.TRACE

TRACE 方法是让 Web 服务器端将之前的请求通信环回给客户端的方法。

发送请求时,在 Max-Forwards 首部字段中填入数值,每经过一个服务器端就将该数字减 1,当数值刚好减到 0 时,就停止继续传输,最

后接收到请求的服务器端则返回状态码 200 OK 的响应。

客户端通过 TRACE 方法可以查询发送出去的请求是怎样被加工修改/ 篡改的。这是因为,请求想要连接到源目标服务器可能会通过代理中转,TRACE 方法就是用来确认连接过程中发生的一系列操作。

但TRACE 方法本来就不怎么常用,再加上它容易引发XST(Cross-Site Tracing,跨站追踪)攻击,通常就更不会用到了。


2.4.8.CONNECT

CONNECT方法要求在与代理服务器通信时建立隧道,实现用隧道协议进行TCP通信。

主要使用 SSL(Secure Sockets Layer,安全套接层)和 TLS(Transport Layer Security,传输层安全)协议把通信内容加密后经网络隧道传输。


2.5.使用方法下达命令

相关推荐
编程乐趣1 小时前
一个超快低延迟.Net网络通信库:支持TCP, SSL, UDP, HTTP,HTTPS, WebSocket多协议
tcp/ip·http·ssl
小度爱学习1 小时前
TCP、UDP的区别及使用场景
服务器·网络·网络协议·tcp/ip·计算机网络·网络安全·udp
路星辞*2 小时前
TCP/UDP/IP报文大小
运维·网络·网络协议·tcp/ip
这猪好帅4 小时前
【Linux网络编程】高效I/O--I/O的五种类型
linux·网络
Mars--5 小时前
华为数通-访问控制列表
网络·华为
SuperherRo10 小时前
基础入门-抓包技术&HTTPS协议&APP&小程序&PC应用&Web&证书信任&转发联动
http·小程序·https·pc应用·转发联动
几维安全11 小时前
手机与平板:勒索软件的“天然通道”
网络·智能手机·电脑
jinan88611 小时前
出差人员携带的电脑文件信息安全如何保障?
大数据·运维·服务器·网络·安全·电脑