安全基础-互联网技术基础

互联网技术基础

概述:计算机网络、网络协议、HTTP协议、前端与后端技术、Web服务器、数据库以及浏览器等`


目录

  • 互联网技术基础
  • 前言
  • 一、计算机网络定义
  • 二、网络协议和协议分层
    • 1.OSI七层模型
    • 2.TCP/IP四层模型
  • 三、HTTP协议
    • 1、HTTP协议的特点
    • 2、HTTP请求
    • 3、HTTP响应
    • 4、HTTP协议的版本
  • 四、前端和后端
    • 1、前端(Frontend)
    • 2、后端(Backend)
    • 3、总结
  • 五、Web服务器
    • 1、Web服务器的主要功能
    • 2、常见的Web服务器软件
    • 3、Web服务器的工作流程
  • 六、数据库
    • 1、数据库的作用
    • 2、数据库的类型
  • 七、浏览器
    • 1、浏览器的作用
    • 2、浏览器的工作原理
    • 3、常见的浏览器
  • 八、URL
    • 1、URL的组成
    • 2、URL的作用
  • 九、浏览器框架
    • 1、早期浏览器时代(1990s - 2000s)
    • 2、多进程架构的引入(2000s - 2010s)
    • 3、服务化架构的发展(2010s - 至今)
    • 4、现代浏览器的多样化发展
    • 5、未来发展趋势
  • 十、总结


前言

本章节计算机网络、网络协议、HTTP协议、前端与后端技术、Web服务器、数据库以及浏览器等多个方面,理解网站是如何运行的,并从全局视角掌握相关技术。


一、计算机网络定义

计算机网络是指将地理位置分散的多台计算机设备通过通信线路和网络设备连接起来,实现资源共享、信息传递和通信的一种系统。它使得不同计算机之间可以进行数据交换和通信,从而提高工作效率、降低成本和促进信息共享。
计算机网络的基本组成包括:

  • 网络硬件:包括计算机、网络适配器(网卡)、集线器、交换机、路由器、中继器等网络设备,以及传输介质(如双绞线、同轴电缆、光纤等)。
  • 网络软件:包括网络操作系统、网络通信协议、网络应用软件等。网络操作系统负责管理网络资源和提供网络服务,如Windows Server、Linux等;网络通信协议规定了数据传输的规则和格式,如TCP/IP协议;网络应用软件则是在网络上运行的各种应用程序,如电子邮件、网页浏览器、文件传输程序等。
  • 通信线路:是连接网络设备和计算机的物理介质,负责数据的传输。常见的通信线路有双绞线、同轴电缆、光纤等,它们各有特点,如双绞线成本低、安装方便,但传输距离较短;光纤传输距离远、带宽大,但成本较高。

计算机网络按其覆盖范围可分为局域网(LAN)、城域网(MAN)和广域网(WAN)等类型。局域网通常覆盖一个办公室或建筑内的计算机设备,城域网覆盖一个城市范围内的计算机设备,而广域网则可以覆盖一个国家甚至全球的计算机设备,如互联网就是一种广域网。

计算机网络的应用非常广泛,包括但不限于以下方面:

  • 数据通信:如电子邮件、即时通讯、网络电话等,使人们能够快速、方便地进行信息交流。
  • 资源共享:如文件共享、打印共享、数据库共享等,提高了资源的利用率,减少了重复投资。
  • 远程教育:通过网络课程、在线讲座等方式,使人们能够跨越地域限制接受教育。
  • 电子商务:通过网络进行商品交易、支付结算等,极大地促进了商业的发展和经济的繁荣。
  • 网络娱乐:如在线游戏、网络视频、音乐下载等,丰富了人们的文化生活。

二、网络协议和协议分层

网络协议是计算机网络中通信双方共同遵守的规则和约定,它规定了数据的格式、传输方式、传输速率、传输步骤等,以确保数据能够正确地在网络中传输和交换。网络协议是实现网络通信的基础,它定义了网络中不同设备和应用程序之间如何进行通信和协作。

应用分层是将复杂的网络通信过程分解为若干个层次,每个层次负责不同的功能,从而简化网络设计和实现。这种分层结构使得网络协议的开发和维护更加模块化和灵活。常见的网络协议分层模型有OSI七层模型和TCP/IP四层模型。

1.OSI七层模型

OSI(Open Systems Interconnection)七层模型是一个理论上的网络通信模型,由国际标准化组织(ISO)提出。它将网络通信过程分为七个层次。

  1. 物理层(Physical Layer):
    • 负责在物理媒介上实现原始比特流的传输。它定义了物理连接的电气、机械、过程和功能特性,如电缆、连接器、电压等级等。
    • 常见的物理层协议有RS-232、V.35等。
  2. 数据链路层(Data Link Layer):
    • 负责在相邻节点之间建立数据链路连接,将物理层传输的原始比特流组织成帧,并进行帧同步、差错控制和流量控制等。
    • 常见的数据链路层协议有以太网(Ethernet)、点对点协议(PPP)等。
  3. 网络层(Network Layer):
    • 负责将数据从源节点传输到目的节点,主要解决数据包的寻址和路由问题。它定义了网络地址、路由选择算法和拥塞控制等。
    • 常见的网络层协议有IP协议(Internet Protocol)等。
  4. 传输层(Transport Layer):
    • 负责为应用层提供端到端的通信服务,确保数据的可靠传输。它定义了数据传输的格式、顺序和完整性,以及错误检测和重传机制等。
    • 常见的传输层协议有TCP(传输控制协议)和UDP(用户数据报协议)等。
  5. 会话层(Session Layer):
    • 负责建立、管理和终止应用程序之间的会话连接。它提供会话的同步和恢复功能,确保会话的连续性和一致性。
    • 会话层的功能在实际应用中通常由应用层协议实现,如SSL/TLS会话管理等。
  6. 表示层(Presentation Layer):
    • 负责数据的表示、安全和压缩等。它将数据转换为适合网络传输的格式,如数据加密、解密、编码、解码等。
    • 常见的表示层协议有ASCII、MPEG、JPEG等。
  7. 应用层(Application Layer):
    • 负责提供各种网络应用服务,如文件传输、电子邮件、远程登录、网络浏览等。它定义了应用程序如何使用下层网络服务来实现其功能。
    • 常见的应用层协议有HTTP(超文本传输协议)、FTP(文件传输协议)、SMTP(简单邮件传输协议)等。

2.TCP/IP四层模型

TCP/IP四层模型是实际应用中更常见的网络协议模型,它简化了OSI七层模型,将功能相近的层次合并,分为以下四个层次:

  1. 链路层(Link Layer):
    • 对应OSI模型的物理层和数据链路层。负责在物理媒介上实现数据的传输和链路管理,包括帧的封装、传输和解封装等。
    • 常见的链路层协议有以太网(Ethernet)、PPP等。
  2. 网络层(Internet Layer):
    • 对应OSI模型的网络层。负责数据包的寻址和路由,将数据从源节点传输到目的节点。
    • 常见的网络层协议有IP协议等。
  3. 传输层(Transport Layer):
    • 对应OSI模型的传输层。负责提供端到端的通信服务,确保数据的可靠传输。
    • 常见的传输层协议有TCP和UDP等。
  4. 应用层(Application Layer):
    • 对应OSI模型的会话层、表示层和应用层。负责提供各种网络应用服务,实现应用程序之间的通信和协作。
    • 常见的应用层协议有HTTP、FTP、SMTP等。

在实际的网络通信中,数据从发送方的应用层开始,逐层向下封装,经过链路层发送到网络上;在接收方,数据逐层向上解封装,最终到达应用层。每一层都只与相邻的上下层进行交互,通过接口和协议实现数据的传输和处理。这种分层结构使得网络协议的设计和实现更加清晰和高效。

三、HTTP协议

HTTP(超文本传输协议,Hypertext Transfer Protocol)是一种用于传输超文本的协议,是互联网上应用最为广泛的协议之一。HTTP协议定义了客户端(如浏览器)与服务器之间如何进行通信和交换数据。它是一种无状态的、面向请求/响应的协议,主要用于从服务器传输超文本到本地浏览器。

1、HTTP协议的特点

  • 无状态性:HTTP协议是无状态的,这意味着服务器不会保存客户端请求的任何状态信息。每次请求都是独立的,服务器不会记住之前的请求。不过,可以通过使用Cookie等技术来模拟状态。
  • 请求/响应模式:HTTP通信基于请求和响应模式。客户端发送一个HTTP请求到服务器,服务器处理请求后返回一个HTTP响应给客户端。
  • 简单灵活:HTTP协议简单易用,客户端和服务器之间通过简单的文本格式进行通信,易于理解和实现。
  • 支持多种数据类型:HTTP协议支持多种数据类型,包括文本、图片、视频、音频等,通过设置不同的Content-Type头部字段来指定数据类型。
  • 可扩展性:HTTP协议具有良好的扩展性,可以通过自定义头部字段和状态码来满足不同的需求。

2、HTTP请求

HTTP请求由请求行、请求头部和请求体组成。

  • 请求行:包括请求方法、请求URI(统一资源标识符)和HTTP版本。常见的请求方法有:
    • GET:请求获取指定资源的信息,是最常用的请求方法。
    • POST:请求服务器接收客户端发送的数据,通常用于提交表单数据或上传文件。
    • PUT:请求服务器保存客户端发送的数据,通常用于更新资源。
    • DELETE:请求服务器删除指定的资源。
    • HEAD:与GET类似,但服务器只返回响应头,不返回响应体。
    • OPTIONS:请求服务器返回支持的HTTP方法。
    • CONNECT:用于建立隧道,常用于HTTP代理。
  • 请求头部:包含客户端发送的各种信息,如主机地址(Host)、用户代理(User-Agent)、内容类型(Content-Type)、内容长度(Content-Length)、Cookie等。
  • 请求体:在POST和PUT等请求方法中,请求体包含客户端要发送给服务器的数据。

3、HTTP响应

HTTP响应由状态行、响应头部和响应体组成。

  • 状态行:包括HTTP版本、状态码和状态消息。状态码是一个三位数字,用于表示请求的结果:
    • 1xx:信息性状态码,表示请求已被接收,继续处理。
    • 2xx:成功状态码,表示请求已成功被服务器接收、理解、接受并处理。
      • 200 OK:请求成功。
      • 201 Created:请求成功并且服务器创建了新的资源。
      • 204 No Content:服务器成功处理了请求,但不需要返回任何实体内容。
    • 3xx:重定向状态码,表示需要进一步的操作以完成请求。
      • 301 Moved Permanently:请求的资源已被永久移动到新的URI。
      • 302 Found:请求的资源临时移动到新的URI。
    • 4xx:客户端错误状态码,表示客户端请求有误。
      • 400 Bad Request:服务器无法理解请求的格式。
      • 401 Unauthorized:请求要求用户的身份认证。
      • 403 Forbidden:服务器理解请求,但拒绝执行。
      • 404 Not Found:请求的资源在服务器上未找到。
    • 5xx:服务器错误状态码,表示服务器在处理请求时发生了错误。
      • 500 Internal Server Error:服务器内部错误。
      • 502 Bad Gateway:作为网关或代理工作的服务器,从上游服务器接收到无效响应。
      • 503 Service Unavailable:服务器当前无法处理请求,但可能在将来可用。
  • 响应头部:包含服务器发送的各种信息,如内容类型(Content-Type)、内容长度(Content-Length)、服务器信息(Server)、日期(Date)等。
  • 响应体:包含服务器返回给客户端的数据,如HTML文档、图片、视频等。

4、HTTP协议的版本

  • HTTP/1.0:最初的HTTP版本,每个连接只能处理一个请求和响应,然后关闭连接。
  • HTTP/1.1:在HTTP/1.0的基础上进行了改进,支持持久连接(Connection: keep-alive),允许在一个TCP连接上发送多个请求和响应,减少了连接的开销。还支持分块传输编码、主机头部字段、管道化等特性。
  • HTTP/2:基于SPDY协议,对HTTP/1.x进行了重大改进,支持二进制协议、头部压缩、服务器推送、并行传输等特性,提高了传输效率和性能。
  • HTTP/3:基于QUIC协议,进一步改进了传输性能和安全性,支持UDP传输、更低的连接延迟、更好的拥塞控制等特性。
  • HTTP协议是构建现代网络应用的基础,广泛应用于网页浏览、文件下载、API通信等场景。随着互联网的发展,HTTP协议也在不断地演进和完善,以满足日益增长的网络需求。

四、前端和后端

前端和后端是软件开发中的两个主要领域,它们分别负责不同的功能和职责。

1、前端(Frontend)

  • 定义:前端通常指的是用户可以直接与之交互的应用程序部分。它包括用户界面(UI)和用户体验(UX)的设计与实现。
  • 主要职责:
    • 用户界面设计:设计和实现用户看到的界面元素,如按钮、文本框、菜单、图表等。
    • 交互逻辑:处理用户的输入和操作,响应用户的交互行为,如点击事件、表单提交、动画效果等。
    • 数据展示:将后端提供的数据以友好的方式展示给用户,如列表、表格、图表等。
  • 技术栈:
    • HTML:用于构建网页的结构和内容。
    • CSS:用于设置网页的样式和布局。
    • JavaScript:用于实现网页的交互逻辑和动态效果。
  • 前端框架和库:如React、Vue.js、Angular等,用于提高开发效率和实现复杂的用户界面。
  • 版本控制工具:如Git,用于代码管理和版本控制。
  • 工作重点:前端开发的重点在于提供良好的用户体验,确保界面美观、响应快速、交互流畅。
  • 运行环境:前端代码主要在用户的浏览器中运行,因此需要考虑浏览器兼容性和性能优化。

2、后端(Backend)

  • 定义:后端通常指的是应用程序的服务器端部分,负责处理应用程序的业务逻辑、数据存储和管理等。
  • 主要职责:
    • 业务逻辑:实现应用程序的核心功能和业务规则,如用户认证、订单处理、数据计算等。
    • 数据存储:管理和存储应用程序的数据,如用户信息、产品数据、订单数据等,通常使用数据库来存储数据。
    • API设计:设计和实现应用程序编程接口(API),供前端调用以获取数据和执行操作。
  • 服务器管理:维护服务器的运行环境,确保应用程序的稳定性和安全性。
    技术栈:
  • 编程语言:如Python、Java、C#、Ruby、Node.js等,用于编写服务器端代码。
  • 数据库:如MySQL、PostgreSQL、MongoDB、Redis等,用于存储和管理数据。
  • 服务器框架:如Django、Spring、Express等,用于快速开发和部署后端应用。
  • 服务器和部署工具:如Nginx、Apache、Docker、Kubernetes等,用于服务器配置和应用部署。
  • 工作重点:后端开发的重点在于实现应用程序的业务逻辑,确保数据的准确性和安全性,以及提供高效的API服务。
  • 运行环境:后端代码主要在服务器上运行,因此需要考虑服务器的性能、负载均衡和安全性等。

3、总结

  • 用户交互:前端直接与用户交互,关注用户界面和体验;后端不直接与用户交互,关注业务逻辑和数据处理。
  • 运行位置:前端代码运行在用户的浏览器中,后端代码运行在服务器上。
  • 技术栈:前端主要使用HTML、CSS、JavaScript等技术,后端则使用各种编程语言、数据库和服务器框架等。
  • 职责分工:前端负责展示和交互,后端负责逻辑和数据管理。

在实际的软件开发过程中,前端和后端通常是紧密协作的,通过API进行通信和数据交换,共同实现应用程序的整体功能。

五、Web服务器

Web服务器是用于存储、处理和提供网页内容给客户端(通常是浏览器)的服务器软件或硬件设备。它接收来自客户端的HTTP请求,根据请求的内容查找相应的资源(如HTML文件、图片、视频等),并将这些资源作为HTTP响应发送给客户端。Web服务器是构建Web应用和提供Web服务的基础。

1、Web服务器的主要功能

  • 处理HTTP请求:接收客户端发送的HTTP请求,解析请求中的方法、URI、头部信息等,确定客户端需要的资源。
  • 资源定位:根据请求的URI,查找服务器上存储的相应资源文件。如果资源存在,则进行下一步处理;如果资源不存在,则返回404 Not Found错误。
  • 响应生成:将找到的资源文件转换为HTTP响应格式,包括设置响应状态码、响应头部(如Content-Type、Content-Length等)和响应体(即资源内容)。
  • 发送响应:将生成的HTTP响应通过TCP连接发送给客户端,客户端收到响应后可以展示网页内容。
  • 日志记录:记录服务器处理请求的详细信息,如请求时间、客户端IP地址、请求方法、请求URI、响应状态码等,用于分析服务器的访问情况和性能。
  • 安全防护:提供一定的安全机制,如身份认证、访问控制、SSL/TLS加密等,保护服务器和资源的安全。

2、常见的Web服务器软件

  • Apache HTTP Server:是最流行的Web服务器之一,具有高度的可配置性和扩展性,支持多种操作系统平台。它提供了丰富的模块和插件,可以实现各种功能,如URL重写、缓存、代理等。
  • Nginx:以其高性能、高并发和低资源消耗而著称。Nginx在处理静态资源、负载均衡、反向代理等方面表现优异,常用于作为反向代理服务器和负载均衡器。
  • Microsoft IIS(Internet Information Services):是微软开发的Web服务器,集成在Windows操作系统中。它提供了简单易用的管理界面和良好的与Windows系统的集成性,适合在Windows环境下部署Web应用。
  • Lighttpd:是一款轻量级的Web服务器,专为高性能和低资源消耗而设计。它适用于嵌入式设备和小型Web应用。
  • Tomcat:虽然Tomcat本身是一个Servlet容器,但它也可以作为Web服务器使用。它主要用于运行Java Web应用,支持Servlet和JSP技术。

3、Web服务器的工作流程

  1. 监听请求:Web服务器在指定的端口(通常是80端口)上监听客户端的HTTP请求。
  2. 接收请求:当客户端发送HTTP请求时,服务器接收请求数据,并解析请求中的信息。
  3. 处理请求:
    • 如果请求的是静态资源(如HTML文件、图片等),服务器直接从文件系统中读取资源内容,并生成HTTP响应。
    • 如果请求的是动态资源(如需要执行脚本或程序生成的内容),服务器会调用相应的处理程序(如CGI脚本、ASP.NET程序等),由处理程序生成动态内容,然后服务器将其转换为HTTP响应。
  4. 发送响应:服务器将生成的HTTP响应通过TCP连接发送给客户端。
  5. 关闭连接:对于HTTP/1.0,默认在发送完响应后关闭TCP连接;对于HTTP/1.1,如果请求头部中包含Connection: keep-alive,则保持连接,以便后续请求复用该连接。

Web服务器是Web应用架构中的关键组件,它为客户端提供网页内容和Web服务,使得用户可以通过浏览器访问和使用各种Web应用。随着互联网的发展,Web服务器也在不断地优化和改进,以满足日益增长的性能和功能需求。

六、数据库

数据库是用于存储、管理和组织数据的系统,它允许用户以高效、安全和可控的方式访问和操作数据。数据库通常由一个或多个数据表组成,每个数据表包含一组相关的数据记录,每条记录由多个字段(或列)组成,字段定义了数据的类型和结构。

1、数据库的作用

  1. 数据存储:
    • 提供一个集中存储数据的地方,可以存储大量的结构化数据,如用户信息、订单数据、产品信息等。
    • 支持不同类型的数据存储,包括文本、数字、日期、时间、二进制数据等。
  2. 数据管理:
    • 提供数据的增删改查(CRUD)操作,方便用户对数据进行管理。
    • 支持数据的排序、筛选、分组、聚合等操作,方便用户对数据进行分析和处理。
  3. 数据一致性:
    • 通过约束(如主键约束、外键约束、唯一性约束等)确保数据的完整性和一致性,避免数据的重复、冲突和错误。
    • 支持事务管理,确保数据操作的原子性、一致性、隔离性和持久性(ACID特性),即使在并发操作或系统故障的情况下也能保证数据的正确性。
  4. 数据安全性:
    • 提供用户权限管理,可以根据用户的角色和权限设置对数据的访问和操作权限,防止未授权访问和数据泄露。
    • 支持数据加密、备份和恢复等安全措施,保护数据的安全性和可靠性。
  5. 数据共享:
    • 支持多用户同时访问和操作数据库中的数据,实现数据的共享和协作。
    • 提供数据库连接和访问接口,方便应用程序和系统之间进行数据交换和集成。
  6. 提高效率:
    • 使用索引、查询优化等技术提高数据检索的效率,快速响应用户的查询请求。
    • 支持批量操作和自动化管理,减少人工干预,提高数据处理的效率和准确性。

2、数据库的类型

  • 关系型数据库(RDBMS):
    • 使用表格的形式组织数据,表与表之间通过关系(如外键)进行关联。
    • 采用SQL(结构化查询语言)作为查询和操作数据的标准语言。
    • 常见的关系型数据库有MySQL、PostgreSQL、Oracle、SQL Server等。
  • 非关系型数据库(NoSQL):
    • 不使用表格形式,而是采用键值对、文档、列族、图等数据模型来组织数据。
    • 适用于处理大规模、分布式、多样化和快速变化的数据。
    • 常见的非关系型数据库有MongoDB(文档型)、Redis(键值存储型)、Cassandra(列族型)、Neo4j(图型)等。

数据库在现代信息系统中扮演着核心角色,广泛应用于企业、政府、教育、医疗等领域,是实现数据驱动决策、业务流程管理和信息共享的重要基础。

七、浏览器

浏览器是一种用于访问和浏览互联网上信息的软件应用程序。它允许用户通过互联网获取和查看网页、图片、视频、音频等各种类型的资源。浏览器是互联网用户与网络内容交互的主要工具之一。

1、浏览器的作用

  1. 网页浏览:
    • 解析和渲染网页:浏览器能够解析HTML、CSS和JavaScript等网页语言,将网页代码转换为用户可以阅读和交互的图形界面。
    • 提供导航功能:用户可以通过点击链接、输入网址、使用前进和后退按钮等方式在不同的网页之间导航。
  2. 资源下载:
    • 允许用户下载网页上的资源,如图片、视频、音频、文件等。
    • 支持多种下载方式,包括直接点击下载链接、右键菜单下载等。
  3. 表单提交:
    • 支持用户填写和提交表单数据,如登录、注册、搜索、购买等操作。
    • 将用户输入的数据发送到服务器,并接收服务器的响应结果。
  4. 多媒体播放:
    • 内置或支持第三方插件,可以播放网页中的多媒体内容,如视频、音频、动画等。
    • 支持多种多媒体格式和播放功能,如暂停、播放、快进、快退、音量调节等。
  5. 交互式功能:
    • 支持JavaScript等脚本语言,实现网页的交互式功能,如动态内容更新、表单验证、动画效果等。
    • 提供API和接口,允许开发者创建丰富的Web应用和交互体验。
  6. 安全和隐私保护:
    • 提供安全机制,如HTTPS加密、跨站脚本(XSS)防护、内容安全策略(CSP)等,保护用户的网络安全。
    • 提供隐私设置,如清除浏览历史、管理Cookie、阻止弹窗广告等,保护用户的隐私信息。
  7. 扩展和插件支持:
    • 支持安装和使用各种扩展程序和插件,以增强浏览器的功能和用户体验。
    • 扩展和插件可以提供额外的功能,如广告拦截、密码管理、网页翻译、开发工具等。
  8. 开发者工具:
    • 提供内置的开发者工具,方便开发者调试和优化网页和Web应用。
    • 开发者工具包括元素检查器、控制台、网络分析器、性能分析器等。

2、浏览器的工作原理

  • 用户输入:用户在浏览器的地址栏输入网址或点击链接,发起资源请求。
  • 请求发送:浏览器将请求发送到服务器,通过DNS解析域名,建立TCP连接,发送HTTP请求。
  • 服务器响应:服务器处理请求,返回相应的资源(如HTML文件、图片等)作为HTTP响应。
  • 资源加载:浏览器接收响应,加载和解析资源,构建DOM树和CSSOM树,渲染网页内容。
  • 用户交互:用户与网页进行交互,如点击按钮、填写表单等,浏览器根据JavaScript代码执行相应的操作。

3、常见的浏览器

  • Google Chrome:由谷歌公司开发,以其快速、安全和丰富的扩展功能而著称。
  • Mozilla Firefox:由Mozilla基金会开发,注重用户隐私和开源社区支持。
  • Microsoft Edge:微软开发的浏览器,基于Chromium内核,兼容性好,性能优异。
  • Safari:苹果公司开发的浏览器,主要用于macOS和iOS系统,注重性能和能效。
  • Opera:挪威Opera软件公司开发的浏览器,支持多种平台,具有独特的功能和设计。

浏览器作为互联网的重要入口,极大地丰富了用户的信息获取和交互方式,推动了互联网的发展和应用。随着技术的进步,浏览器的功能和性能也在不断提升,为用户提供了更加便捷和安全的网络体验。

八、URL

URL(Uniform Resource Locator,统一资源定位符)是互联网上用来标识和定位资源的一种标准格式。它提供了一种简单的方法来访问网络上的资源,如网页、图片、视频、文件等。URL是用户在浏览器地址栏中输入以访问特定资源的地址。

1、URL的组成

一个典型的URL通常由以下几个部分组成:

  • 协议(Scheme):
    • 指定了访问资源所使用的协议类型。常见的协议有:
      • http:超文本传输协议,用于访问普通的网页资源。
      • https:安全超文本传输协议,是HTTP的安全版本,通过SSL/TLS加密传输数据,用于保护敏感信息的安全传输。
      • ftp:文件传输协议,用于文件的上传和下载。
      • file:用于访问本地文件系统中的文件。
      • mailto:用于发送电子邮件。
    • 协议后面通常跟随一个冒号和两个斜杠[ : / / ],表示协议的结束和资源地址的开始。
  • 主机名(Host):
    • 指定了资源所在的服务器的域名或IP地址。域名是通过DNS解析为IP地址的,以便浏览器能够找到服务器的位置。
    • 例如,在URL https://www.example.com 中,www.example.com 就是主机名。
  • 端口号(Port):
    • 指定了服务器上用于监听请求的端口号。端口号是可选的,如果省略,则使用协议的默认端口号(如HTTP的默认端口号是80,HTTPS的默认端口号是443)。
    • 如果需要指定非默认端口号,则在主机名后面加上冒号和端口号。例如:https://www.example.com:8080。
  • 路径(Path):
    • 指定了服务器上资源的具体位置,通常是一个文件夹或文件的路径。路径可以是绝对路径或相对路径。
    • 例如,在URL https://www.example.com/path/to/resource.html 中,/path/to/resource.html 就是路径。
  • 查询字符串(Query String):
    • 用于向服务器传递额外的参数信息,通常用于动态网页的请求。查询字符串以问号(?)开始,后面跟随一个或多个参数,参数之间用&分隔。
    • 例如:https://www.example.com/search?query=keyword&page=2 中的 ?query=keyword&page=2 就是查询字符串,表示传递了两个参数:query 和 page。
  • 锚点(Fragment):
    • 用于定位页面内的特定位置,通常用于跳转到页面中的某个部分。锚点以井号(#)开始,后面跟随一个标识符。
    • 例如:https://www.example.com/page.html#section1 中的 #section1 就是锚点,表示跳转到页面中ID为section1的部分。

2、URL的作用

  • 资源定位:URL提供了资源在网络上的唯一标识,使得用户能够准确地找到和访问特定的资源。
  • 数据传输:通过URL的查询字符串,可以向服务器传递请求参数,实现动态内容的加载和数据的交互。
  • 导航和链接:在网页中,URL用于创建超链接,允许用户通过点击链接从一个资源跳转到另一个资源,实现网页之间的导航和连接。
  • 搜索引擎优化(SEO):URL的结构和内容对搜索引擎优化有重要影响,合理的URL设计有助于提高网页的排名和可见度。

URL是互联网通信的基础之一,它使得用户能够方便地访问和获取网络上的各种资源。随着互联网的发展,URL的设计和使用也在不断优化和创新,以满足日益增长的网络需求。

九、浏览器框架

浏览器框架的演进是一个随着技术发展和用户需求变化而不断进步的过程。以下是浏览器框架的主要演进阶段:

1、早期浏览器时代(1990s - 2000s)

  • 静态页面时代:
    • 初期的浏览器主要用于显示静态的HTML页面,功能相对简单,主要关注于文本和图片的展示。
    • 代表性的浏览器有Netscape Navigator和Internet Explorer,它们在浏览器市场中占据主导地位。

2、多进程架构的引入(2000s - 2010s)

  • 多进程浏览器:
    • 为了提高浏览器的稳定性和性能,现代浏览器采用了多进程架构。每个标签页或插件运行在一个独立的进程中,这样即使一个页面崩溃,也不会影响整个浏览器。
    • Google Chrome是多进程架构的典型代表,它通过将渲染、GPU、网络等模块分离,大大提高了浏览器的稳定性和安全性。

3、服务化架构的发展(2010s - 至今)

  • 面向服务的架构(SOA):
    • Chrome团队在2016年提出了面向服务的架构,将浏览器的基础能力拆解成一个个独立的服务,每个服务运行在一个独立的进程中。
    • 这种架构使得浏览器更加轻量、高效,便于维护和扩展。

4、现代浏览器的多样化发展

  • 移动浏览器的崛起:
    • 随着智能手机的普及,移动浏览器成为了一个重要的发展方向。它们需要针对移动设备的特点进行优化,如屏幕尺寸、触摸操作和性能。
  • 功能的丰富和扩展:
    • 现代浏览器不仅用于网页浏览,还集成了各种功能,如密码管理、广告拦截、开发者工具等。
    • 浏览器的插件和扩展生态系统也不断发展,允许用户根据自己的需求定制浏览器。

5、未来发展趋势

  • 性能和安全性的提升:
    • 浏览器将继续在性能和安全性方面进行优化,提供更快的加载速度和更强大的安全防护。
  • 跨平台和多设备支持:
    • 随着物联网和多设备互联的发展,浏览器将更好地支持跨平台和多设备的使用场景。
  • 集成新技术:
    • 浏览器可能会更多地集成人工智能、语音交互、虚拟现实等新技术,提供更智能和丰富的用户体验。

浏览器框架的演进反映了互联网技术的快速发展和用户需求的不断变化,未来浏览器将继续在功能、性能和用户体验等方面不断创新和进步。


十、总结

本章节包含计算机网络、网络协议、HTTP协议、前端与后端技术、Web服务器、数据库以及浏览器等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/950601.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LAMP搭建

LAMP搭建 引子:本篇文章为LAMP的搭建流程,其中L(Ubuntu)、A(Apache)、M(Mysql)、P(PHP)。 一、L → Ubuntu Step 1:在Vmware Workstation中使…

LabVIEW 系统诊断

LabVIEW 系统诊断是指通过各种工具和方法检测、评估、分析和解决 LabVIEW 程序和硬件系统中可能存在的故障和性能问题。系统诊断不仅涵盖软件层面的调试与优化,还包括硬件交互、数据传输、实时性能等方面的检查和分析。一个成功的系统诊断能够显著提升LabVIEW应用程…

基于 GEE 提取白莲种植范围

目录 1 方法原理 1.1 步骤一 1.2 步骤二 1.3 步骤三 1.4 步骤四 2 完整代码 3 运行结果 近年来,随着乡村振兴战略的提出,我国的农业种植模式呈现出多元化的趋势。白莲具有易种植、经济效益高的特点,由此被广泛种植,本文介绍…

el-table 自定义表头颜色

第一种方法&#xff1a;计算属性 <template><div><el-table:data"formData.detail"border stripehighlight-current-row:cell-style"{ text-align: center }":header-cell-style"headerCellStyle"><el-table-column fixed…

c++类和对象---上

文章目录 类的介绍 类的声明 1.1 类名 1.2 成员变量 1.3 成员函数 1.4 访问权限 类的定义 2.1 成员变量的初始化 2.2 成员函数的实现 对象的创建和销毁 3.1 默认构造函数 3.2 析构函数 3.3 拷贝构造函数 3.4 对象的实例化 3.5 对象的销毁 成员访问控制 4.1 公有成员 4.2 私有…

上汽乘用车研发流程

目的 最近刚入职主机厂&#xff0c;工作中所提到各个阶段名称与之前在供应商那边不一致&#xff0c;概念有点模糊&#xff0c;所以打算学习了解一番 概念 术语 EP: enginerring prototype car 工程样车 Mule Car: 骡子车 Simulator Car&#xff1a;模拟样车 PPV&#xff1a;…

阿里云发现后门webshell,怎么处理,怎么解决?

当收到如下阿里云通知邮件时&#xff0c;大部分管理员都会心里一惊吧&#xff01;出现Webshell&#xff0c;大概是网站被入侵了。 尊敬的 xxxaliyun.com&#xff1a; 云盾云安全中心检测到您的服务器&#xff1a;47.108.x.xx&#xff08;xx机&#xff09;出现了紧急安全事件…

vite5.x配置https

旧版的vite直接在config里面配置https&#xff1a;true即可&#xff0c;新版的麻烦一些。 1.准备工作 需要安装openssl 下载地址&#xff1a;Win32/Win64 OpenSSL Installer for Windows - Shining Light Productions 找到合适的版本安装&#xff0c;配置好环境变量&#x…

深度学习与计算机视觉 (博士)

文章目录 零、计算机视觉概述一、深度学习相关概念1.学习率η2.batchsize和epoch3.端到端(End-to-End)、序列到序列(Seq-to-Seq)4.消融实验5.学习方式6.监督学习的方式(1)有监督学习(2)强监督学习(3)弱监督学习(4)半监督学习(5)自监督学习(6)无监督学习(7)总结&#xff1a;不同…

在AI浪潮中,RSS3为何会被低估其价值?有何潜力

​​RSS3 简介&#xff1a; RSS3 是一个去中心化网络索引和结构化开放信息&#xff0c;使其对于下一个 Twitter、Google 和 OpenAI 来说易于访问且有价值。凭借独特的数据子层价值子层设计&#xff0c; RSS3 网络推动了开放信息从索引到消费等的全生命周期&#xff0c;并建立了…

BMS应用软件开发 — 3 电池系统的组成

目录 1 电池的基本拓扑 2 已经被淘汰的CTM 3 早已经普及的CTP 4 集成度更高的CTC 5 刚性更好的CTB 1 电池的基本拓扑 相比于燃油车&#xff0c;虽然电动车在结构空间上灵活度更高&#xff0c;空间利用率也更好&#xff0c;但现有条件下无法像燃油车一样快速补能&#xff…

UE5 打包要点

------------------------- 1、需要环境 win sdk &#xff0c;大约3G VS&#xff0c;大约10G 不安装就无法打包&#xff0c;就是这么简单。 ----------------------- 2、打包设置 编译类型&#xff0c;开发、调试、发行 项目设置-地图和模式&#xff0c;默认地图 项目…

高等数学学习笔记 ☞ 一元函数微分的基础知识

1. 微分的定义 &#xff08;1&#xff09;定义&#xff1a;设函数在点的某领域内有定义&#xff0c;取附近的点&#xff0c;对应的函数值分别为和&#xff0c; 令&#xff0c;若可以表示成&#xff0c;则称函数在点是可微的。 【 若函数在点是可微的&#xff0c;则可以表达为】…

Redis查询缓存

什么是缓存&#xff1f; 缓存是一种提高数据访问效率的技术&#xff0c;通过在内存中存储数据的副本来减少对数据库或其他慢速存储设备的频繁访问。缓存通常用于存储热点数据或计算代价高的结果&#xff0c;以加快响应速度。 添加Redis缓存有什么好处&#xff1f; Redis 基…

3D立体无人机夜间表演技术详解

3D立体无人机夜间表演技术是一种结合了无人机技术、灯光艺术和计算机编程的创新表演形式。以下是该技术的详细解析&#xff1a; 一、技术基础 1. 无人机技术&#xff1a; 无人机通常采用四旋翼设计&#xff0c;具有强大的飞行控制能力&#xff0c;可以实现前飞、后飞、悬停、…

MATLAB深度学习实战文字识别

文章目录 前言视频演示效果1.DB文字定位环境配置安装教程与资源说明1.1 DB概述1.2 DB算法原理1.2.1 整体框架1.2.2 特征提取网络Resnet1.2.3 自适应阈值1.2.4 文字区域标注生成1.2.5 DB文字定位模型训练 2.CRNN文字识别2.1 CRNN概述2.2 CRNN原理2.2.1 CRNN网络架构实现2.2.2 CN…

H2数据库在单元测试中的应用

H2数据库特征 用比较简洁的话来介绍h2数据库&#xff0c;就是一款轻量级的内存数据库&#xff0c;支持标准的SQL语法和JDBC API&#xff0c;工业领域中&#xff0c;一般会使用h2来进行单元测试。 这里贴一下h2数据库的主要特征 Very fast database engineOpen sourceWritten…

Android 10.0 授权app获取cpu温度和电池温度功能实现

1.前言 在10.0的系统定制化开发中&#xff0c;在开发某些产品的老化应用的时候&#xff0c;需要app获取cpu温度和电池 温度等功能&#xff0c;有些产品带温度传感器&#xff0c;大部分的产品都不包含温度传感器&#xff0c;所以就需要读取 sys下的相关节点来获取相关温度值 2.…

IDEA 撤销 merge 操作(详解)

作为一个开发者&#xff0c;我们都知道Git是一个非常重要的版本控制工具&#xff0c;尤其是在协作开发的过程中。然而&#xff0c;在使用Git的过程中难免会踩一些坑&#xff0c;今天我来给大家分享一个我曾经遇到的问题&#xff1a;在使用IDEA中进行merge操作后如何撤销错误的合…

WD5105同步降压转换器:9.2V-95V宽电压输入,4.5A大电流输出,95%高效率,多重保护功能

概述 • WD5105同步降压转换器 • 封装形式&#xff1a;QFN-20封装 • 应用场景&#xff1a;适用于车载充电器、电动车仪表、电信基站电源、电源适配器等 性能特点 • 输入电压范围&#xff1a;9.2V至95V • 输出电流&#xff1a;可提供4.5A连续负载电流 • 效率&#xff1a;高…