HTTP协议
本文目录
- HTTP协议
- 一.HTTP协议
- 1.概要
- 二.请求消息
- 1.request请求消息组成
- 2.1 请求行
- 2.2 请求头
- 2.3 请求空行
- 2.4 请求体(正文)
- 2.请求消息的字符串格式
- 三.响应消息
- 2.1 响应行
- 2.2 响应头
- 2.3 响应空行
- 2.4 响应体
一.HTTP协议
1.概要
HTTP协议概念:Hyper Text Transfer Protocol
超文本传输协议。
传输协议:定义了,客户端和服务器端通信时,发送数据的格式。
特点:
- 基于TCP/IP的高级协议
- 默认端口号:80
- 基于请求/响应模型的:一次请求对应一次响应
- 无状态的:每次请求之间相互独立,不能交互数据
历史版本:
HTTP1.0:每一次请求响应都会建立新的连接
HTTP1.1:可以复用连接
二.请求消息
请求消息:客户端发送给服务器端的数据
1.request请求消息组成
数据格式:
- 请求行
- 请求头
- 请求空行
- 请求体
2.1 请求行
请求方式 请求uri 请求协议/版本
GET /login.html HTTP/1.1
请求方式:HTTP协议有7种请求方式,常用的有2种,GET和POST
7种请求方式:GET、POST、HEAD、PUT、 DELETE、CONNECT、 OPTIONS、TRACE。
GET方式:
- 请求参数在请求行中,在url后。
- 请求的url长度有限制的
- 不太安全
POST方式:
- 请求参数在请求体中
- 请求的url长度没有限制的
- 相对安全
常见面试题
说说你对get和post请求的了解,并且说说它们之间的区别?
1.get请求用来从服务器上获得资源,而post是用来向服务器提交数据;
2.get将表单中数据按照name=value的形式,添加到action所指向的URL后面,并且两者使用"?“连接,而各个变量之间使用”&“连接;
post是将表单中的数据放在HTTP协议的请求头或者消息体中,传递到action所指向URL;
3.get传输的数据要受到URL长度限制(1024字节);
post可以传输大量的数据,上传文件通常要使用post方式;
4.使用get时参数会显示到地址栏上,如果这些数据不是敏感数据,可以使用;
对于敏感数据还是应该使用post;
5.get使用MIME类型application/x-www-form-urlencoded的URL编码(也叫百分号编码)文本的格式传递参数,传输中文可能会乱码,保证被传送的参数由遵循规范的文本组成,例如一个空格的编码是”%20"。
含有中文的数据,应该使用post方式。
2.2 请求头
请求头:客户端浏览器告诉服务器一些信息。
格式是:
- 请求头名称: 请求头值
常见的请求头:
-
User-Agent
:浏览器告诉服务器,我访问你使用的浏览器版本信息
可以在服务器端获取该头的信息,解决浏览器的兼容性问题 -
Referer
:http://localhost/login.html
告诉服务器,我(当前请求)从哪里来?
作用:1. 防盗链;2. 统计工作,可以统计从哪个url访问的数量;
2.3 请求空行
空行,就是用于分割POST请求的请求头,和请求体的。GET请求没有请求空行,因为请求参数是存在URL里。
2.4 请求体(正文)
封装POST请求消息的请求参数的。
2.请求消息的字符串格式
POST /login.html HTTP/1.1
Host: localhost
User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Referer: http://localhost/login.html
Connection: keep-alive
Upgrade-Insecure-Requests: 1
username=zhangsan
空行表示请求空行;
username=zhangsan:请求参数;
三.响应消息
响应消息:服务器端发送给客户端的数据
响应消息的字符串格式,省略了一些响应头:
HTTP/1.1 200 OK
Content-Type: text/html;charset=UTF-8
Content-Length: 101
Date: Wed, 06 Jun 2018 07:08:42 GMT
<html>
<head>
<title>$Title$</title>
</head>
<body>
hello , response
</body>
</html>
数据格式:
- 响应行
- 响应头
- 响应空行
- 响应体
2.1 响应行
响应消息的第一行,描述协议版本,响应状态等。
组成:协议/版本 响应状态码 状态码描述
HTTP/1.1 200 OK
响应状态码
响应状态码指:服务器告诉客户端浏览器本次请求和响应的一个状态。
状态码都是3位数字,分类有:
- 1xx:服务器就收客户端消息,但没有接受完成,等待一段时间后,发送1xx多状态码
- 2xx:成功。代表:200
- 3xx:重定向。代表:302(重定向),304(访问缓存)
- 4xx:客户端错误。代表:404(请求路径没有对应的资源);405(请求方式没有对应的doXxx方法)
- 5xx:服务器端错误。代表:500(服务器内部出现异常)
了解常见的状态码,可以帮助我们快速定位错误情况。
2.2 响应头
响应头格式
响应头头名称:值
常见的响应头:
-
Content-Type
:服务器告诉客户端本次响应体数据格式以及编码格式 Content-disposition
:服务器告诉客户端以什么格式打开响应体数据,值有:
- in-line:默认值,在当前页面内打开
- attachment;filename=xxx:以附件形式打开响应体。文件下载,xxx表示弹窗上显示出来的文件名称
2.3 响应空行
就是一个空行,分割响应头和响应体的。
2.4 响应体
响应体是服务器响应请求,传输到客户端浏览器的数据。
到这结束啦,记录HTTP学习笔记,方便回顾所学知识。