面试官别再问我HTTP了
nanshan 2025-05-28 19:20 26 浏览 0 评论
HTTP常见的状态响应码
2XX:一般都表示成功
- 200(OK):服务器成功处理了客户端的请求
- 204(No Content):与200相同,只不过响应的Body里面没有数据
- 206(Partial Content):应用于HTTP分块下载和断点续传,表示响应的Body是部分资源
3XX:一般表示客户端请求的资源发生了变动,客户端需要用新的URL再次访问
- 301(Moved Peromanently):永久重定向,请求的资源不存在,使用新的URL访问
- 302(Not Found):临时重定向,请求的资源还在,暂时使用另一个URL访问
- 304(Not Modified):表示资源未修改,重定向已存在的缓冲文件,也称缓存重定向,用于缓存控制
301和302都会在响应头里使用Location字段,指明后续要跳转的URL
4XX:表示客户端发送的报文有错误
- 400(Bad Request):表示客户端请求的报文有错误
- 403(Forbidden):服务器禁止访问资源
- 404(Not Found):客户端请求的资源未找到
5XX:服务器内部处理错误
- 500(Internal Server Error):服务器内部错误
- 501(Not Implemented):客户端请求的功能不支持
- 502(Bad Gateway):服务器自身工作正常,但访问后端服务发生错误,通常是服务器作为网关或代理时返回(比如Nginx)
- 503(Service Unavailable):服务器繁忙,无法响应
Http的常见字段
Request Headers
- Host:服务器域名
- Connection:HTTP/1.1默认都是长连接,为了兼容老版本HTTP,指定此字段的值为keep-alive
- Accept:客户端指定自己能够接收的数据格式
- Accept-Encoding:客户端指定自己能够接收的数据压缩方式
Response Headers
- Content-Length:服务器响应数据的长度
- Content-Type:告诉客户端服务器返回的数据格式
- Content-Encoding:告诉客户端服务器返回的数据使用的压缩格式
HTTP请求方式的幂等性?
- GET:幂等
- PUT:幂等
- DELETE:幂等
- POST:不幂等
HTTP的优点
- 简单:报文就是header + body,形式就是key-value
- 灵活易于扩展:HTTP请求中的各个字段都没有被固定死,允许自定义扩展
- 跨平台
HTTP的缺点
- 无状态:无法记录一些用户登录信息,一些关联的操作比较麻烦(购物车)
- 不安全
HTTP不安全表现
- 明文传输,内容被窃听,导致账号信息容易泄漏
- 不验证通信双方身份,容易遭遇伪装,比如访问假的拼夕夕
- 无法验证报文完整性,内容被篡改,比如网页植入广告
HTTP与HTTPS的区别
- HTTP明文传输不安全,HTTPS在TCP和HTTP之间引入SSL/TLS协议可以加密传输
- HTTP连接建立简单,TCP三次握手以后便可以传输,HTTPS需要在TPC三次握手以后进行SSL/TSL握手,成功以后才可以传输
- HTTP的端口是80,HTTPS是443
- HTTPS需要向CA申请数字证书,用来验证服务器身份可靠
HTTPS如何解决安全问题
- 混合加密解决窃听风险:通信建立前使用非对称加密交换会话密钥,通信过程中使用对称加密加密数据
- 摘要算法保证数据完整性
- 数字证书保证服务器可靠
SSL/TLS的握手过程
- 首先是由客户端发出加密通信请求(ClientHello),请求中包含的信息如下:
- 客户端支持的协议版本,比如TLS1.0还是TLS1.2
- 一个客户端生成的随机数,后面用于生成会话秘钥
- 客户端支持的加密方式,比如RSA加密算法
- 支持的压缩方法
- 服务器收到ClientHello请求后,进行响应(ServerHello),响应的信息如下:
- 确认使用的协议版本,如果浏览器与服务器支持的版本不一致,则关闭加密通信
- 服务器生成的随机数,后面用于生成会话密钥
- 确认使用的加密方法,比如RSA加密算法
- 服务器的数字证书
- 客户端收到服务端的响应以后需要进行回应,在回应之前会首先通过浏览器或操作系统预置的CA公钥验证数字证书的有效性,如果证书不是可信机构颁发、或者证书中的域名和实际域名不一致,或者证书已过期都会给访问者一个警告,由访问者决定是否继续通信。
如果证书验证没问题,就从证书中取出服务器的公钥,然后使用它加密报文,向服务器发送以下信息:
- 一个随机数(pre-master key),该随机数会被服务器的公钥加密
- 加密通信算法改变通知,表示随后的通信都使用会话密钥加密通信
- 客户端结束握手通知,表示客户端的握手阶段已经结束,同时把之前的内容做个摘要,用来供服务端验证
此时一共有3个随机数,服务器和客户端会通过这三个随机数以及协商好的加密算法,各自生成本次通信的会话密钥。
- 服务器在收到客户端的随机数以后(pre-master),通过协商的加密算法,计算出本次通信的会话密钥,向客户端发送以下信息:
- 加密算法改变通知,表示随后的通信都使用会话密钥加密通信
- 服务器结束握手通知,表示服务端握手结束,同时把之前的内容做个摘要发送给客户端用来验证
至此,SSL/TLS握手结束,后续就是普通HTTP协议,只不过会使用会话秘钥来加密
HTTP1.1的优点
- 使用长连接的方式减少了HTTP1.0短连接的性能开销
- 支持管道传输,请求发出以后不必等待响应即可发送第二个请求
HTTP1.1的缺点
- 请求响应头部在发送时没有压缩,只能压缩Body
- 首部过于冗长,相同的首部发送浪费资源
- 服务器是按照请求顺序响应,容易导致队头阻塞
- 无法控制请求优先级
- 请求只能由客户端发起,服务端只能响应
HTTP2的优点
- 基于HTTPS,安全性得到保障
- 头部压缩(HPACK算法),提高发送速度
- 报文采用二进制格式,统称为帧,头信息为头信息帧,数据体为数据帧,接收端在收到报文后无需再解析
- 数据流,每个请求或响应的所有数据报称为数据流,每个数据流有唯一编号,通过指定数据流的优先级,服务器会根据优先级顺序进行响应
- 多路复用,响应顺序可以和请求顺序不对应,解决对头阻塞问题
- 服务器可以主动向客户端发送消息
HTTP2的缺点
- 多个HTTP请求复用一个TCP连接,如果TCP发生了重传,所有的HTTP请求都必须等待丢了的包被重传回来
基于上述问题HTTP3的下层协议由TCP改为UDP,然后通过QUIC协议保证传输的可靠性,但目前普及速度缓慢,这里就不说了。
相关推荐
- Linux 中如何提取压缩文件 ?(linux怎么解压到当前文件夹)
-
Linux是一种流行的开源操作系统,它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间,使数据传输更快。本指南将向您展示如何在Linux中提取不同类型的压缩文件。1.Unpa...
- 在 WSL 中体验 Unix 哲学:从发消息到加密传输文件
-
Unix哲学强调小而简单的工具,利用它们组合起来完成复杂的任务。WindowsSubsystemforLinux(WSL)为我们提供了一个可以在Windows上运行Linux工具的...
- 还在用数据线?这样传文件简直不要太方便!支持多设备互传!
-
这是一款局域网文件传输工具,它支持windows端、安卓端、苹果端、和linux端的设备在同一局域网下进行文件互传,省去了数据线连接的麻烦。工具我已经为大家打包好了,有兴趣的朋友可以在这里获取。大家好...
- Linux远程文件传输神器:rz / sz 全指南(含实操示例)
-
原文链接:「链接」在日常使用Linux服务器时,是否常常因为文件传输问题而苦恼?复制粘贴效率低,FTP配置复杂?今天推荐一套简单高效的终端工具组合:rz和sz。这两个命令搭配使用,能在本地与...
- 机房搬迁后域控服务器失联?原因令人乍舌,看我如何快速修复
-
一、问题背景:一场搬迁后引发的连锁故障为某客户的主域服务器升级内存,因为我们知道有备域,所以也就没多想,直接关闭了主域服务器,可是刚打开机箱盖,就有用户反馈,不能上网了,紧接着,各部门都来反馈断网,难...
- 办公室SSH服务器远程访问,重启自动建立通道
-
背景可以通过一台外网服务器建立来自Internet上的客户与办公室SSH服务的连接。Ubuntu下可以使用如下命令。autossh-M0-o"ServerAliveInterval3...
- Windows Autopatch热修复功能上线:企业PC Win11更新无需重启
-
IT之家6月25日消息,今年5月,微软为Windows11设备发布了首个热修复更新,并在同一时期为WindowsAutopatch添加了热修复功能。Autopatch是微软的...
- 路由器设置优化指南,小白也能轻松上手!
-
【ZOL中关村在线原创技巧应用】在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器,不知道如何设置才能上网。本文将用通俗易懂的方式,一步步教你完成设...
- 如何防止DDoS攻击导致的服务中断(如何防止服务器被ddos)
-
防止DDoS(分布式拒绝服务)攻击导致的服务中断需要结合多种技术和策略。DDoS是通过大量恶意流量压垮服务器或网络资源,使正常用户无法访问服务。以下是针对DDoS攻击的预防措施和应对策略,帮...
- 零配置网络与.local 后缀(零配置失败)
-
在小型的家庭网络或办公室环境中,你可能经常遇到这样的场景:想要访问网络中的一台设备,比如家里的网络打印机、智能音箱,或者一个共享文件服务器,但你不知道它的具体IP地址。每次都要去路由器后台查看或者...
- 蓝牙无法搜索到设备?全面排查与解决指南
-
蓝牙作为主流无线连接技术,偶尔会出现“无法搜索到设备”的问题,这类故障多由设备状态、设置错误或兼容性问题引发。以下是一套系统化的排查方案,从基础检查到深度修复,帮你快速恢复蓝牙连接功能。一、快速检...
- 电脑网络出现黄色感叹号?一文教你彻底解决无网络连接问题
-
当电脑右下角的网络图标突然亮起黄色感叹号,显示"无Internet连接"时,这种突如其来的断网状况往往让人措手不及。无论是正在进行的视频会议、即将提交的工作文件,还是在线游戏的关键时刻...
- 手机信号恢复最简单的方法(手机信号怎么修)
-
重启手机或开关飞行模式信号恢复最简单的方法是重启手机或开关飞行模式,这一操作能快速刷新网络连接,解决80%以上的临时性信号丢失问题。快速恢复信号的简易步骤开关飞行模式。下拉通知栏,开启飞行模式等待10...
- 《Windows 学习:100 条命令大全》内容总结
-
一、文件与目录管理1.基础操作dir:用于列出当前目录下的文件和子目录。在命令提示符中输入dir,即可显示当前目录的内容,如文件名称、大小、修改日期等信息。若想查看隐藏文件,可使用dir/a命令。...
- 路由器亮红灯:网络“健康警报”的全面解读与自救指南
-
当你发现路由器的指示灯突然泛起红光,往往代表着你的网络连接已出现严重问题。面对这一情况,不必惊慌。本文将带你一步步拆解红灯背后的常见原因,并提供系统性的解决方案,让你从被动等待转为主动修复。红灯亮起的...
你 发表评论:
欢迎- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
手机如何设置与显示准确时间的详细指南
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
一加手机与电脑互传文件的便捷方法FileDash
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)