HTTP报文的结构

HTTP请求方法对照表
HTTP状态码对照表

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&param2=value2的键值对形式编码成一个格式化串,它承载多个请求参数的数据。不但报文体可以传递请求参数,请求URL也可以通过类似于“/chapter15/user.html? param1=value1&param2=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放到这里.

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值