HTTP请求报文解剖
HTTP Request :HTTP请求
Request Line:请求行
Header:请求头
Request Body:请求体
HTTP请求报文由3部分组成(请求行+请求头+请求体):
下面是一个实际的请求报文:
①是请求方法,HTTP/1.1 定义的请求方法有8种:GET、POST、PUT、DELETE、PATCH、HEAD、OPTIONS、TRACE,最常的两种GET和POST。
②为请求对应的URL地址,它和报文头的Host属性组成完整的请求URL
③是协议名称及版本号。
④是HTTP的报文头,报文头包含若干个属性,格式为“属性名:属性值”,服务端据此获取客户端的信息。
⑤是报文体,它将一个页面表单中的组件值通过param1=value1¶m2=value2的键值对形式编码成一个格式化串,它承载多个请求参数的数据。不但报文体可以传递请求参数,请求URL也可以通过类似于“/chapter15/user.html? param1=value1¶m2=value2”的方式传递请求参数。
对照上面的请求报文,我们把它进一步分解,你可以看到一幅更详细的结构图:
HTTP响应报文解剖
HTTP的响应报文也由三部分组成(响应行+响应头+响应体):
以下是一个实际的HTTP响应报文:
①报文协议及版本;
②状态码及状态描述;
③响应报文头,也是由多个属性组成;
④响应报文体,即我们真正要的“干货”。
响应状态码
和请求报文相比,响应报文多了一个“响应状态码”,它以“清晰明确”的语言告诉客户端本次请求的处理结果。
HTTP的响应状态码由5段组成:
1xx 消息,一般是告诉客户端,请求已经收到了,正在处理,别急...
2xx 处理成功,一般表示:请求收悉、我明白你要的、请求已受理、已经处理完成等信息.
3xx 重定向到其它地方。它让客户端再发起一个请求以完成整个处理。
4xx 处理发生错误,责任在客户端,如客户端的请求一个不存在的资源,客户端未被授权,禁止访问等。
5xx 处理发生错误,责任在服务端,如服务端抛出异常,路由出错,HTTP版本不支持等。
200 OK
你最希望看到的,即处理成功!
303 See Other
我把你redirect(重定向)到其它的页面,目标的URL通过响应报文头的Location告诉你。服务器:我这里没有, 去这个url试试.
304 Not Modified
告诉客户端,你请求的这个资源至你上次取得后,并没有更改,你直接用你本地的缓存吧,我很忙哦,你能不能少来烦我啊!
404 Not Found
你最不希望看到的,即找不到页面。如你在google上找到一个页面,点击这个链接返回404,表示这个页面已经被网站删除了,google那边的记录只是美好的回忆。
500 Internal Server Error
看到这个错误,你就应该查查服务端的日志了,肯定抛出了一堆异常,别睡了,起来改BUG去吧!
关于这部分, 面试官爱问的几个问题.
1. 说下http报文的结构?
HTTP报文有请求报文和响应报文. 请求报文包括 请求行,请求头,请求体. 响应报文包括 响应行,响应头,响应体.
2. get/post是属于上述的哪一部分, 后续传的参数在什么地方?
get/post属于请求行. 如果是get请求, 参数拼接在url中; 如果是post请求, 参数在请求体中.
3. 上传图片用什么方式? 图片在哪一部分?
上传图片用post, post上传理论上无大小限制(除非服务器限制), 图片放到请求体中, 放在 multipart/form-data; boundary 下, boundary是一串字符, 用来分割文件的.
4. 请求头里都有哪些字段? 都是什么含义? 能说几个算几个.
这个问题就随缘吧,没必要特别记, 常见的能说几个就是了, 下面几个是我用过的, http://tools.jb51.net/table/http_header
Accept 指定客户端能够接收的内容类型, 一般是application/json , text/json , text/plain, text/html...
Cookie HTTP请求发送时,会把保存在该请求域名下的所有cookie值一起发送给web服务器。
Connection 表示是否需要持久连接。(HTTP 1.1默认进行持久连接)
Content-Length 请求的内容长度
Content-Type 请求的与实体对应的MIME信息, 文件上传的时候要改成对应的文件信息, image/jpeg, image/png , application/octet-stream
If-Modified-Since 如果请求的资源在指定时间之后被修改则请求成功,未被修改则返回304代码
ETag 本地变量的实体标签的值, 这个和上面的If-Modified-Since配合着用, ETag就是对应资源的md5
Range 只请求实体的一部分指定范围, 断点续传会用到这个 , Content-Range 是服务器返回的,告诉客户端从这个位置开始返回数据
User-Agent User-Agent的内容包含发出请求的用户信息
Authorization 客户端提供给服务器的认证信息, 我们会把用户的token放到这里.