Http协议面试题

本文深入解析HTTP协议的基础概念,包括其工作原理、请求方法、状态码、首部字段等关键信息,对比HTTP1.0与1.1的区别,探讨GET与POST请求的不同,以及HTTP与HTTPS的优缺点。

1.什么HTTP协议

● 对客户端和服务器端之间数据传输的格式规范,格式简称为“超文本传输协议”

2.什么是HTTP协议无状态协议?怎么解决http协议无状态协议?

● 无状态协议对于事物处理没有记忆能力。缺少状态意味着后续的处理需要前面的信息。
● 无状态协议的解决办法:通过1)Cookie ; 2)通过session会话保存。

3.说一下HTTP协议中302状态

● HTTP协议中,返回302状态码表示重定向。
● 这种情况下服务器返回的头部信息中会包含一个Location字段,内容是重定向到的URL。

4.HTTP协议有什么组成?

请求报文包含三部分:
● 请求行:包含请求方法,URL,HTTP版本信息
● 请求首部字段
● 请求内容实体

响应报文包含三部分:
● 状态行:包含HTTP版本,状态码,状态码的原因短语
● 响应首部字段
● 响应内容实体

说一下网络传输过程

1189489-20180514091936031-871926134.png

5.Http协议中有那些请求方式?

● GET: 用于请求访问已经被URI(统一资源标识符)识别的资源,可以通过URL传参给服务器
● POST:用于传输信息给服务器,主要功能与GET方法类似,但一般推荐使用POST方式。
● PUT: 传输文件,报文主体中包含文件内容,保存到对应URI位置。
● HEAD: 获得报文首部,与GET方法类似,只是不返回报文主体,一般用于验证URI是否有效。
● DELETE:删除文件,与PUT方法相反,删除对应URI位置的文件。
● OPTIONS:查询相应URI支持的HTTP方法。

6.HTTP协议中HTTP1.0和1.1 有什么区别

● 在HTTP1.0中,当连接建立后,客户端发送一个请求,服务器端返回一个信息后就关闭了连接。当浏览器下次要请求是又要重新建立连接,显然这种不断建立连接的方式会造成很多问题。
●在HTTP1.1中,引入了持续连接的概念,通过这种连接浏览器建立一个连接之后,发送请求并得到返回消息,然后继续发送请求再次得到返回消息,也就是说客户端可以连续发送多个请求,而不用等待每一个响应的到来。

7.get与post请求的区别

区别一:
● get重点是从服务器上获取资源
● post重点是向服务器发送数据。
区别二:
● get传输数据是通过URL请求,以field(字段) = value的形式,置于URL后,并用“?”连接,多个请求数据间用“&”连接,如http://127.0.0.1/Test/login.action?name=admin&password=admin,这个过程用户是可见的。
● post传输数据是通过HTTP的post机制。将字段和对应值封存在请求实体中发送给服务器。这个过程用户是不可见的。
区别三:
● get传输数据量小,因为受URL长度限制,但是效率高。
● post可以传输大量数据,所以上传文件时只能用post
区别四:
● get是不安全的,因为URL是可见的,可能会泄漏私密信息。
● post 较get安全性高
区别五:
● get方式只能支持ASCII字符,向服务器传的中文字符可能会乱码。
● post支持标准字符集,可以正确传递中文字符。

9.常见Http协议状态?

200:请求被正常处理
204:请求被受理但没有资源可以返回
206:客户端只是请求资源的一部分,服务器只对请求的部分资源执行GET方法,相应报文中通过Content-Range指定范围的资源。
301:永久性重定向
302:临时重定向
303:与302状态码有相似功能,只是它希望客户端在请求一个URI的时候,能通过GET方法重定向到另一个URI上
304:发送附带条件的请求时,条件不满足时返回,与重定向无关
307:临时重定向,与302类似,只是强制要求使用POST方法
400:请求报文语法有误,服务器无法识别
401:请求需要认证
403:请求的对应资源禁止被访问=
404:服务器无法找到对应资源
500:服务器内部错误
503:服务器正忙

10.Http协议首部字段?

a、通用首部字段(请求报文与响应报文都会使用的首部字段)

Date:创建报文时间
Connection:连接的管理
Cache-Control:缓存的控制
Transfer-Encoding:报文主体的传输编码方式

b、请求首部字段(请求报文会使用的首部字段)
Host:请求资源所在服务器
Accept:可处理的媒体类型
Accept-Charset:可接收的字符集
Accept-Encoding:可接受的内容编码
Accept-Language:可接受的自然语言

c、响应首部字段(响应报文会使用的首部字段)
Accept-Ranges:可接受的字节范围
Location:令客户端重新定向到的URI
Server:HTTP服务器的安装信息

d、实体首部字段(请求报文与响应报文的的实体部分使用的首部字段)
Allow:资源可支持的HTTP方法
Content-Type:实体主类的类型
Content-Encoding:实体主体适用的编码方式
Content-Language:实体主体的自然语言
Content-Length:实体主体的的字节数
Content-Range:实体主体的位置范围,一般用于发出部分请求时使用

11.Http与Https优缺点?

通信使用明文不加密,内容可能被窃听,也就是被抓包分析。
不验证通信方身份,可能遭到伪装
无法验证报文完整性,可能被篡改
HTTPS就是HTTP加上加密处理(一般是SSL安全通信线路)+认证+完整性保护

12.Http优化

利用负载均衡优化和加速HTTP应用
利用HTTP Cache来优化网站

13.Http协议有那些特征?

1、支持客户/服务器模式;2、简单快速;3、灵活;4、无连接;5、无状态。



作者:S_ZY
链接:https://www.jianshu.com/p/511e051f709c
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

### HTTP协议相关面试题整理 #### 1. HTTP协议的基本概念 HTTP(Hyper Text Transfer Protocol)是超文本传输协议,用于从万维网服务器传输超文本到本地浏览器的传送协议[^1]。它是一个基于TCP/IP通信协议来传递数据的协议,例如HTML文件、图片文件、查询结果等。 #### 2. HTTP的工作原理 HTTP协议的工作过程可以分为以下几个方面:客户端与服务器建立连接后,客户端发送请求给服务器;服务器接收请求并返回相应的响应信息;最后,客户端关闭连接[^1]。整个过程包括请求和响应两个阶段。 #### 3. HTTP状态码分类及常见状态码 HTTP状态码分为五类: - **1xx**:信息性状态码,表示接收到请求并且继续处理。 - **2xx**:成功状态码,表示请求已被成功接收、理解和处理。 - **3xx**:重定向状态码,表示需要进一步操作以完成请求。 - **4xx**:客户端错误状态码,表示请求包含语法错误或无法完成。 - **5xx**:服务器错误状态码,表示服务器未能实现合法请求。 常见的状态码包括: - `200 OK`:请求成功。 - `301 Moved Permanently`:永久重定向。 - `404 Not Found`:请求的资源不存在。 - `500 Internal Server Error`:服务器内部错误[^1]。 #### 4. HTTPHTTPS的区别 - **安全性**:HTTPS通过SSL/TLS加密技术保证数据的安全性,而HTTP是明文传输。 - **端口号**:HTTP默认使用80端口,HTTPS默认使用443端口。 - **性能**:HTTPS由于加密解密的过程,会增加一定的计算开销[^1]。 #### 5. HTTP/1.1与HTTP/2.0的区别 - **多路复用**:HTTP/2.0支持在同一连接上并发处理多个请求,避免了HTTP/1.1中的队头阻塞问题。 - **头部压缩**:HTTP/2.0采用HPACK算法对头部数据进行压缩,减少传输体积,提高传输效率。 - **二进制帧**:HTTP/2.0将头部和数据部分都转换为二进制帧,而HTTP/1.1的头部信息是文本格式。 - **服务器推送**:HTTP/2.0允许服务器主动推送资源到客户端,提升页面加载速度[^3]。 #### 6. 持久连接与非持久连接 - **非持久连接**:每次请求都需要重新建立TCP连接,适合短时间内的少量请求。 - **持久连接**:在一个TCP连接中可以多次发送请求和响应,减少了连接建立和关闭的开销,适用于大量请求场景。 #### 7. 缓存机制 HTTP缓存通过`Cache-Control`、`Expires`、`ETag`等头字段实现。缓存可以减少重复请求,降低服务器负载,提高用户体验。 #### 8. 条件请求 条件请求通过`If-Modified-Since`或`If-None-Match`头字段实现。当资源未被修改时,服务器返回`304 Not Modified`,否则返回完整的资源内容。 #### 9. Cookie与Session的区别 - **Cookie**:存储在客户端的小型数据块,通常用于保存用户会话信息。 - **Session**:存储在服务器端的数据结构,用于跟踪用户的会话状态。Session ID通常通过Cookie传递。 #### 10. 常见的HTTP方法 - `GET`:请求获取指定资源。 - `POST`:向指定资源提交数据,请求服务器进行处理。 - `PUT`:上传完整资源到指定位置。 - `DELETE`:删除指定资源。 - `HEAD`:请求获取响应头信息,不包含实体主体。 - `OPTIONS`:请求获取目标资源所支持的通信选项[^1]。 ### 示例代码:简单的HTTP请求与响应 ```python import http.server import socketserver PORT = 8000 Handler = http.server.SimpleHTTPRequestHandler with socketserver.TCPServer(("", PORT), Handler) as httpd: print(f"Serving at port {PORT}") httpd.serve_forever() ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值