计算机网络-理论部分(二):应用层

news2025/1/18 8:26:57

网络应用体系结构

  • Client-Server客户-服务器体系结构:如Web,FTP,Telnet等
  • Peer-Peer:点对点P2P结构,如BitTorrent

应用层协议定义了:

  • 交换的报文类型,请求or响应
  • 报文类型的语法
  • 字段的含义
  • 如何发报文,以及响应规则

常见的应用类型有:Web,电子邮件,目录服务,流式视频、P2P
其中目录服务就是DNS解析,将网址转换为IP地址。

Web服务

Web采用的应用协议有

  • HTTP(HyperText Transfer Protocol,超文本传输协议)
  • HTTPS(Hypertext Transfer Protocol Secure,超文本传输安全协议)。

HTTP以明文方式发送内容且没有提供任何形式的数据加密功能,在涉及敏感信息(如信用卡号、密码等支付相关内容)时存在安全隐患。HTTPS在HTTP基础上引入了SSL(Secure Sockets Layer)协议,并通过证书验证服务器身份以确保通信过程中数据得到合理保护和加密处理。

HTTP协议不保存任何Client相关信息,是无状态协议。如果要确认验证信息,可以加入Cookie来解决

发展

初始版本1.0,是非持续连接,每次请求都要建立连接,TCP连接建立和释放影响性能,所以改进提出了HTTP1.1,也是目前主流的HTTP协议。

非持续连接:每个请求/响应都是经单独的TCP发送
持续连接:每个请求/响应都是经过同一个TCP连接发送
持久连接的特点是,只要任意一端没有明确提出断开连接,则保持 TCP 连接状态。如果某个 HTTP 长连接超过一定时间没有任何数据交互,服务端就会主动断开这个连接。
在这里插入图片描述

不过目前都是使用HTTPS协议以保证安全。后续还更新了HTTP2.0和HTTP3.0,HTTP/2.0协议是基于HTTPS的,更加安全,但是目前使用的网站不太多。
在这里插入图片描述

Web缓存器

一个Web缓存器,也叫代理服务器,可以将请求过的数据缓存下来,供再次使用。Client可以先向代理服务器请求,如果代理服务器没有缓存,代理服务器就将请求发到服务器并缓存服务器的响应。如果有缓存则直接发给Client。
在这里插入图片描述

Web缓存器一般是有局部ISP购买安装,使用Web缓存器可以大大减少请求响应时间以及局部ISP链接到主干网的通信量。由此也催生出了提供CDN(Content Distribution Network)内容分发网络服务的服务商。

面试常见问题

  • HTTP的报文
    • 请求报文:请求行(请求方法、URL、协议版本)、请求头、空行、实体体。
      • 常见请求头:Host,User-Agent
      • 常见请求方法:POST,DELETE,PUT,GET
    • 相应报文:状态行(协议版本、状态码、状态码描述)、响应头、空行、实体体。
      • 常见响应头:Date,Content-Type,Content-Length
      • 常见响应状态码:五个范围,1xx是提示收到,需要继续请求;2xx是成功;3xx是资源重定向;4xx是客户端错误;5xx是服务器错误
  • 四种请求方法各自作用和区别
    • GET用于请求数据,对服务器资源无影响,浏览器一般会缓存GET请求结果;请求参数在URL中,安全性比较低。多个参数用&隔开,URL的编码格式采用的是ASCII编码,而不是uniclde,即是说所有的非ASCII字符都要编码之后再传输。
    • POST用于提交数据,对服务器资源有影响,一般不会缓存;POST通过请求体传参,安全性较高。由于浏览器对URL有长度限制,所以GET请求数据大小限制严于POST请求。
    • PUT是向服务端发送数据,请求修改服务端资源;但是不会新增资源。
    • DELETE是请求删除服务端资源,
  • HTTP和HTTPS区别
    • HTTP1.1是明文传输,HTTPS有SSL加密,HTTP2.0是建立在HTTPS基础上的。
    • HTTPS先建立连接,然后服务端发送证书给客户端;确认信任该证书后服务端再要求客户端发送证书并验证(双向身份验证)

DNS服务

DNS提供IP地址查询服务,全球有非常多的DNS服务器,形成层次结构。
在这里插入图片描述
除了上述DNS服务器外,局域ISA中还会提供本地DNS服务器,本地DNS服务器会维护一个DNS缓存,Client需要查询网站IP时,先找本地DNS服务器,如果本地DNS缓存中没有,本地DNS服务器会去找根服务器,根服务器根据域名情况返回对应的DNS服务器IP,本地DNS服务器再找对应DNS查询具体网站IP,最终返回IP地址。

DDoS攻击的原理即:向DNS服务器发送大量DNS请求,使得正常的DNS请求无法得到回复。

Socket套接字

在这里插入图片描述
传输层向应用层提供的接口。
通信需要两个信息:

  • IP地址,用于查找目标终端
  • 端口号,用于查找通信的进程

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

路由器基本原理与配置

一 , 路由是什么? 从源主机到目标主机的转发过程; 二 , 路由器 (1)路由器的工作原理 路由器是一种三层设备,是使用IP地址寻址,实现从源IP到达目标IP地址的端到端的服务&#xff0c…

windows的WSL Ubuntu子系统重置root或其他用户的密码

思路:以管理员身份运行PowerShell,在命令行窗口重置密码 ,不需要删除或重新安装Linux子系统。 1、以管理员身份运行PowerShell 2、用root用户启动Ubuntu,执行 wsl.exe --user root 3、重置密码,执行passwd username&…

autoDL微调训练qwen2vl大模型

autodl是一家GPU服务厂商,提供专业的GPU租用服务,秒级计费、稳定好用 先去autodl把官方的帮助文档看懂先 AutoDL帮助文档 autodl注册并登陆,充钱,根据自己的情况租用新实例 创建新实例后马上关机,因为有个省钱的办法…

9.2 使用haarcascade_frontalface_default.xml分类器检测视频中的人脸,并框出人脸位置。

1)程序代码: # 2.使用haarcascade_frontalface_default.xml分类器检测视频中的人脸,并框出人脸位置 import cv2# 加载人脸检测的 Haar 级联分类器 face_cascade cv2.CascadeClassifier(./data/haarcascades/haarcascade_frontalface_defaul…

K8S containerd拉取harbor镜像

前言 接前面的环境 K8S 1.24以后开始启用docker作为CRI,这里用containerd拉取 参考文档 正文 vim /etc/containerd/config.toml #修改内容如下 #sandbox_image "registry.aliyuncs.com/google_containers/pause:3.10" systemd_cgroup true [plugins.…

ARM64环境部署EFK8.15.3收集K8S集群容器日志

环境规划 主机IP系统部署方式ES版本CPU架构用户名密码192.168.1.225Ubuntu 22.04.4 LTSdockerelasticsearch:8.15.3ARM64elasticllodyi4TMmZD ES集群部署 创建持久化目录(所有节点) mkdir -p /data/es/{data,certs,logs,plugins} mkdir -p /data/es/certs/{ca,es01}服务器…

前端小练习——星辰宇宙(JS没有上限!!!)

前言:在刚开始学习前端的时候,我们会学习到前端三件套中的JavaScript,可能那时候读者没有觉得JavaScript这个语言有多么的牛逼,本篇文章将会使用一个炫酷的案例来刷新你对JavaScript这个语言的认知与理解。 ✨✨✨这里是秋刀鱼不做…

图文教程 | 2024年IDEA安装使用教程,JDK简易下载方法

前言 📢博客主页:程序源⠀-CSDN博客 📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正! 目录 一、IDEA安装 二、激活 三、JDK安装 四、JDK环境配置 五、验证 一、IDEA安装 进入官网下载: Other…

【阅读记录-章节2】Build a Large Language Model (From Scratch)

目录 2.Working with text data2.1 Understanding word embeddings2.2 Tokenizing text通过一个简单的实验来理解文本的词元化概念关键概念 2.3 Converting tokens into token IDs实现分词器类(Tokenizer Class)应用分词器测试文本的编码与解码通过分词器…

已有docker增加端口号,不用重新创建Docker

已有docker增加端口号,不用重新创建Docker 1. 整体描述2. 具体实现2.1 查看容器id2.2 停止docker服务2.3 修改docker配置文件2.4 重启docker服务 3. 总结 1. 整体描述 docker目前使用的非常多,但是每次更新都需要重新创建docker,也不太方便&…

网页作业9

<!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>服务中心</title><style>* {margin:…

HTML and CSS Support HTML 和 CSS 支持

GoTo DevExpress Data Grid 数据网格 HTML and CSS Support HTML 和 CSS 支持 HTML和CSS支持允许您创建完全自定义的UI元素&#xff0c;并消除使用基于属性的UI自定义和CustomDraw事件。您可以构建 HTML 格式的 UI&#xff0c;并使用 CSS 样式自定义 UI 元素的外观设置、大小、…

集群聊天服务器(7)数据模块

目录 Mysql数据库代码封装头文件与源文件 Mysql数据库代码封装 业务层代码不要直接写数据库&#xff0c;因为业务层和数据层的代码逻辑也想完全区分开。万一不想存储mysql&#xff0c;想存redis的话&#xff0c;就要改动大量业务代码。解耦合就是改起来很方便。 首先需要安装m…

如何确保Python爬虫程序的稳定性和安全性?

在当今数字化时代&#xff0c;Python爬虫被广泛应用于数据采集和信息抓取。然而&#xff0c;确保爬虫程序的稳定性和安全性是开发过程中的重要考虑因素。本文将探讨如何通过技术手段和最佳实践来提高Python爬虫的稳定性和安全性&#xff0c;并提供代码示例。 稳定性保障 1. 异…

【知识科普】统一身份认证CAS

什么是CAS 综合概述一、CAS概述二、CAS的组成与工作原理三、CAS的特性与支持四、CAS的应用场景 示例展示场景设定CAS认证过程 其他认证细节CAS认证过程的细节CAS认证过程的特性 参考文献 综合概述 统一身份认证CAS&#xff08;Central Authentication Service&#xff09;&…

golang通用后台管理系统09(系统操作日志记录)

1.日志工具类 package log/**** 日志记录 wangwei 2024-11-18 15:30*/ import ("log""os""path/filepath""time" )// 获取以当前日期命名的日志文件路径 func getLogFilePath() string {currentDate : time.Now().Format("2006-…

解决微信小程序自定义tabbar点击两次才能跳转

在每个页面的js文件下加上此代码&#xff0c;selected属性代表每一个页面的下标&#xff0c;在不同的js文件下&#xff0c;要对应不同的selected值 代码&#xff1a; onShow() { // 确保 TabBar 存在并且设置选中项 if (this.getTabBar && this.getTabBar()) { this.…

golang开源框架:go开源验证框架validator

validator 单个字段格式验证 先来一个单个字段格式的验证 目录结构 在main函数中 package mainimport "awesomeProject/validate"func main() {validate.SingleFieldValidate() }在validator.go中 package validateimport ("github.com/go-playground/val…

【Rust中的项目管理】

Rust中的项目管理 前言Package&#xff0c;Crate&#xff0c;Module &use &#xff0c;Path通过代码示例解释 Crate&#xff0c;Module &#xff0c;use&#xff0c;Path创建一个package&#xff1a;代码组织化skin.rs 中的代码struct & enum 相对路径和绝对路径引用同…

大型语言模型综述 A Survey of Large Language Models

文章源自 2303.18223 (arxiv.org) 如有侵权&#xff0c;请通知下线 这是一篇关于大语言模型&#xff08;LLMs&#xff09;的综述论文&#xff0c;主要介绍了 LLMs 的发展历程、技术架构、训练方法、应用领域以及面临的挑战等方面&#xff0c;具体内容如下&#xff1a; 摘要…