• [x] 互联网的运行方式
  • [ ] 什么是http
  • [ ] TCP和ip
  • [ ] 编码的w3c标准

一、互联网的运行方式

  • Internet 是一个由互连计算机组成的全球网络,这些计算机使用标准化协议(主要是 TCP/IP)进行通信。当您请求网页时,您的设备会通过您的互联网服务提供商 (ISP) 向 DNS 服务器发送数据包,该服务器将网站的域名转换为 IP 地址。然后,数据包通过各种网络(使用路由器和交换机)路由到目标服务器,目标服务器处理请求并发回响应。这种来回交换使网页、电子邮件和文件等数据的传输成为可能,使互联网成为一个动态的、去中心化的全球通信系统。
  • 什么是互联网
  1. 互联网(Internet)就是将世界上所有的计算机连接起来的一种数字网络
  2. 1970年代,温特瑟夫(Vint Cerf)及康恩(Bob Kahn)共同发明了互联网
  3. 世界上所有的计算机共同组成了互联网
  4. 互联网的诞生主要是用于不同计算机之间的数据传输

2.数据是怎么传输的

  • 互联网是一个全然的分散式系统,并没有集中化的控制来决定封包的传递路径,或者是决定每个网络的建立方式,或者是决定谁能跟谁连接
  • 互联网上的信息以数据包的形式从一台电脑传到另一台电脑

3.传输步骤

第一步 浏览器会通过可以连接互联网的Internet服务提供商发送一个请求,该消息包括你的浏览器向计算机发送的一个请求,并使用计算机的IP(Internet协议)地址向服务器发送请求

第二步 域名解析服务器(DNS),请求到达DNS服务器,DNS服务器会将域名解析为IP地址

可以访问的域名必定映射绑定了一台主机,这台主机会有IP,DNS服务器会解析出这个域名对应的哪台主机

第三步 浏览器请求与服务器建立TCP(传输控制协议)连接,发生了发消息的权限

第四步 服务器给出响应,(200 ok)或者(404等异常)

第五步 加入服务器端给出了200ok,建立一个超文本传输协议(http),该协议将创建信息包的级别(相比之下,FTP服务器使用文件传输协议)。每一个数据包都包含一个信息标头,这些信息标头告诉服务器和浏览器该数据包需要到达的位置和用途。

第六步 数据以二进制形式存在。

信息包必须通过该TCP协议传输。这些TCP数据包(实际上是放在复杂信封的数字版本中的比特集合)以低压和高压数据的形式通过电线,电缆或WiFi传输。数据包使用IP地址,使它们知道要去哪里,通过电缆,光纤电缆,电话线和WiFi在路由器之间移动,直到它们穿过为止,但是需要许多路由器才能到达您的实际位置,并且始终在光速,通常横越世界。

有时,数据包会在途中遇到严重拥挤的区域,导致速度变慢,并且必须改变航向,有时,它们会找到返回您的直接路线。

每个路由器仅知道它需要知道的内容。第一路由器可能不知道信息包的最终目的地,但是它知道部分方式。后续路由器知道它需要去的下一个地方,依此类推,直到数据包返回给您。

第七步 服务器允许浏览器将这些单词和图像从数据包中转换为人类可视化的文章。

二、什么是http

1.简介:HTTP( 超文本传输协议)是一种用于从网络传输超文本到本地浏览器的传输协议。它定义了客户端与服务器之间请求和响应的格式。HTTP 工作在 TCP/IP 模型之上,通常使用端口 80。

HTTPS:(超文本传输安全协议)是 HTTP 的安全版本,它在 HTTP 下增加了 SSL/TLS 协议,提供了数据加密、完整性校验和身份验证。HTTPS 通常使用端口 443。

2.工作原理:

http:

  1. 客户端发起请求:用户通过客户端(如浏览器)输入 URL,客户端向服务器发起一个 HTTP 请求。
  2. 服务器处理请求:服务器接收到请求后,根据请求的类型(如GET、POST等)和请求的资源,进行相应的处理。
  3. 服务器返回响应:服务器将处理结果包装成HTTP响应消息,发送回客户端。
  4. 客户端渲染页面:客户端接收到响应后,根据响应内容(如HTML、图片等)渲染页面,展示给用户。

HTTPS的作用:是在不安全的网络上创建一个安全信道,并可在使用适当的加密包和服务器证书可被验证且可被信任时,对窃听和中间人攻击提供合理的防护。

3.区别:1.http传输中不加密,容易被截获和篡改,https使用ssl/tls进行加密更加安全和不容易被截获。

2.http的端口号是80,https是443

http的请求方法

序号

方法

描述

1

GET

从服务器获取资源。用于请求数据而不对数据进行更改。例如,从服务器获取网页、图片等。

2

POST

向服务器发送数据以创建新资源。常用于提交表单数据或上传文件。发送的数据包含在请求体中。

3

PUT

向服务器发送数据以更新现有资源。如果资源不存在,则创建新的资源。与 POST 不同,PUT 通常是幂等的,即多次执行相同的 PUT 请求不会产生不同的结果。

4

DELETE

从服务器删除指定的资源。请求中包含要删除的资源标识符。

5

PATCH

对资源进行部分修改。与 PUT 类似,但 PATCH 只更改部分数据而不是替换整个资源。

6

HEAD

类似于 GET,但服务器只返回响应的头部,不返回实际数据。用于检查资源的元数据(例如,检查资源是否存在,查看响应的头部信息)。

7

OPTIONS

返回服务器支持的 HTTP 方法。用于检查服务器支持哪些请求方法,通常用于跨域资源共享(CORS)的预检请求。

8

TRACE

回显服务器收到的请求,主要用于诊断。客户端可以查看请求在服务器中的处理路径。

9

CONNECT

建立一个到服务器的隧道,通常用于 HTTPS 连接。客户端可以通过该隧道发送加密的数据。

响应头信息

响应头信息(英文)

响应头信息(中文)

描述

Date

日期

响应生成的日期和时间。例如:Wed, 18 Apr 2024 12:00:00 GMT

Server

服务器

服务器软件的名称和版本。例如:Apache/2.4.1 (Unix)

Content-Type

内容类型

响应体的媒体类型(MIME类型),如text/html; charset=UTF-8,application/json等。

Content-Length

内容长度

响应体的大小,单位是字节。例如:3145

Content-Encoding

内容编码

响应体的压缩编码,如gzip,deflate等。

Content-Language

内容语言

响应体的语言。例如:zh-CN

Content-Location

内容位置

响应体的 URI。例如:/index.html

Content-Range

内容范围

响应体的字节范围,用于分块传输。例如:bytes 0-999/8000

Cache-Control

缓存控制

控制响应的缓存行为, 如 no-cache 表示必须重新请求。

Connection

连接

管理连接的选项,如keep-aliveclose,keep-alive 表示连接不会在传输后关闭。。

Set-Cookie

设置 Cookie

设置客户端的 cookie。例如:sessionId=abc123; Path=/; Secure

Expires

过期时间

响应体的过期日期和时间。例如:Thu, 18 Apr 2024 12:00:00 GMT

Last-Modified

最后修改时间

资源最后被修改的日期和时间。例如:Wed, 18 Apr 2024 11:00:00 GMT

ETag

实体标签

资源的特定版本的标识符。例如:"33a64df551425fcc55e6"

Location

位置

用于重定向的 URI。例如:/newresource

Pragma

实现特定的指令

包含实现特定的指令,如no-cache

WWW-Authenticate

认证信息

认证信息,通常用于HTTP认证。例如:Basic realm="Access to the site"

Accept-Ranges

接受范围

指定可接受的请求范围类型。例如:bytes

Age

经过时间

响应生成后经过的秒数,从原始服务器生成到代理服务器。例如:24

Allow

允许方法

列出资源允许的 HTTP 方法 。例如:GET, POST,HEAD等

Vary

变化

告诉下游代理如何使用响应头信息来确定响应是否可以从缓存中获取。例如:Accept

Strict-Transport-Security

严格传输安全

指示浏览器仅通过 HTTPS 与服务器通信。例如:max-age=31536000; includeSubDomains

X-Frame-Options

框架选项

控制页面是否允许在框架中显示,防止点击劫持攻击。例如:SAMEORIGIN

X-Content-Type-Options

内容类型选项

指示浏览器不要尝试猜测资源的 MIME 类型。例如:nosniff

X-XSS-Protection

XSS保护

控制浏览器的 XSS 过滤和阻断。例如:1; mode=block

Public-Key-Pins

公钥固定

HTTP 头信息,用于HTTP公共密钥固定(HPKP),一种安全机制,用于防止中间人攻击。例如:pin-sha256="base64+primarykey"; pin-sha256="base64+backupkey"; max-age=expireTime

状态码

HTTP状态码列表:

状态码

状态码英文名称

中文描述

100

Continue

继续。客户端应继续其请求

101

Switching Protocols

切换协议。服务器根据客户端的请求切换协议。只能切换到更高级的协议,例如,切换到HTTP的新版本协议

200

OK

请求成功。一般用于GET与POST请求

201

Created

已创建。成功请求并创建了新的资源

202

Accepted

已接受。已经接受请求,但未处理完成

203

Non-Authoritative Information

非授权信息。请求成功。但返回的meta信息不在原始的服务器,而是一个副本

204

No Content

无内容。服务器成功处理,但未返回内容。在未更新网页的情况下,可确保浏览器继续显示当前文档

205

Reset Content

重置内容。服务器处理成功,用户终端(例如:浏览器)应重置文档视图。可通过此返回码清除浏览器的表单域

206

Partial Content

部分内容。服务器成功处理了部分GET请求

300

Multiple Choices

多种选择。请求的资源可包括多个位置,相应可返回一个资源特征与地址的列表用于用户终端(例如:浏览器)选择

301

Moved Permanently

永久移动。请求的资源已被永久的移动到新URI,返回信息会包括新的URI,浏览器会自动定向到新URI。今后任何新的请求都应使用新的URI代替

302

Found

临时移动。与301类似。但资源只是临时被移动。客户端应继续使用原有URI

303

See Other

查看其它地址。与301类似。使用GET和POST请求查看

304

Not Modified

未修改。所请求的资源未修改,服务器返回此状态码时,不会返回任何资源。客户端通常会缓存访问过的资源,通过提供一个头信息指出客户端希望只返回在指定日期之后修改的资源

305

Use Proxy

使用代理。所请求的资源必须通过代理访问

306

Unused

已经被废弃的HTTP状态码

307

Temporary Redirect

临时重定向。与302类似。使用GET请求重定向

400

Bad Request

客户端请求的语法错误,服务器无法理解

401

Unauthorized

请求要求用户的身份认证

402

Payment Required

保留,将来使用

403

Forbidden

服务器理解请求客户端的请求,但是拒绝执行此请求

404

Not Found

服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置"您所请求的资源无法找到"的个性页面

405

Method Not Allowed

客户端请求中的方法被禁止

406

Not Acceptable

服务器无法根据客户端请求的内容特性完成请求

407

Proxy Authentication Required

请求要求代理的身份认证,与401类似,但请求者应当使用代理进行授权

408

Request Time-out

服务器等待客户端发送的请求时间过长,超时

409

Conflict

服务器完成客户端的 PUT 请求时可能返回此代码,服务器处理请求时发生了冲突

410

Gone

客户端请求的资源已经不存在。410不同于404,如果资源以前有现在被永久删除了可使用410代码,网站设计人员可通过301代码指定资源的新位置

411

Length Required

服务器无法处理客户端发送的不带Content-Length的请求信息

412

Precondition Failed

客户端请求信息的先决条件错误

413

Request Entity Too Large

由于请求的实体过大,服务器无法处理,因此拒绝请求。为防止客户端的连续请求,服务器可能会关闭连接。如果只是服务器暂时无法处理,则会包含一个Retry-After的响应信息

414

Request-URI Too Large

请求的URI过长(URI通常为网址),服务器无法处理

415

Unsupported Media Type

服务器无法处理请求附带的媒体格式

416

Requested range not satisfiable

客户端请求的范围无效

417

Expectation Failed(预期失败)

服务器无法满足请求头中 Expect 字段指定的预期行为。

418

I'm a teapot

状态码 418 实际上是一个愚人节玩笑。它在 RFC 2324 中定义,该 RFC 是一个关于超文本咖啡壶控制协议(HTCPCP)的笑话文件。在这个笑话中,418 状态码是作为一个玩笑加入到 HTTP 协议中的。

500

Internal Server Error

服务器内部错误,无法完成请求

501

Not Implemented

服务器不支持请求的功能,无法完成请求

502

Bad Gateway

作为网关或者代理工作的服务器尝试执行请求时,从远程服务器接收到了一个无效的响应

503

Service Unavailable

由于超载或系统维护,服务器暂时的无法处理客户端的请求。延时的长度可包含在服务器的Retry-After头信息中

504

Gateway Time-out

充当网关或代理的服务器,未及时从远端服务器获取请求

505

HTTP Version not supported

服务器不支持请求的HTTP协议的版本,无法完成处理

w3c标准

W3C标准涵盖结构化(如HTML、XML)、表现(如CSS)、行为(如DOM、ECMAScript)及其他标准(如HTTP协议、WAI可访问性)多方面,确保网页正确显示、良好体验及数据可访问与互操作。