URL 的语法
<scheme>://<user>:<password>@<host>:<port>/<path>;<params>?<query>#<frag>
报文的语法
请求报文
<method> <request-URL> <version><headers><entity-body>
POST /api/sign/register.json HTTP/1.1Host: :8005Content-Length: 13Accept: */*Origin: :8004DNT: 1Content-Type: application/jsonConnection: keep-alive{"name":"xx"}
响应报文
<version> <status-code> <reason-phrase><headers><entity-body>
HTTP/1.1 200 OKServer: nginx/1.10.3 (Ubuntu)Content-Type: application/jsonTransfer-Encoding: chunkedAccess-Control-Allow-Origin: :8004Access-Control-Allow-Credentials: trueAccess-Control-Allow-Headers: Origin, Content-Type, Cookie, AcceptAccess-Control-Allow-Methods: GET, POST, PATCH, PUT, OPTIONSCache-Control: no-cache, privateDate: Wed, 27 Feb 00:20:44 GMTSet-Cookie: laravel_session=4Q8jPlqCd0Ex9GOa8Nujblgaun8sNs; expires=Wed, 27-Feb- 02:20:44 GMT; Max-Age=7200; path=/; httponlyProxy-Connection: keep-alive{"data":"","code":1001,"msg":"未登录"}
方法(method)
客户端希望服务器对资源执行的动作。是一个单独的词,比如GET、HEAD、或POST等等。
请求URL(request-URL)
命名了所请求资源,或者URL路径组件的完整URL。
版本(version)
报文所使用的 HTTP 版本,其格式看起来是这样的:
HTTP/<major>.<minor>
其中major和minor都是整数
状态码(status-code)
为三位数字,这三位数字描述了请求过程中所发生的情况。每个状态码的第一位数字都用于描述状态的一般类别(“成功”、“出错”等)。
原因短语(reason-phrase)
数字状态码的可读版本,包含行终止序列之前的所有文本。原因短语只对人类有意义。
首部(header)
可以有零个或多个首部,每个首部都包含一个名字,后面跟着一个冒号
:
,然后是一个可选的空格,接着是一个值,最后是一个CRLF
。首部是由一个空行CRLF
结束的,表示了首部列表的结束和实体主体部分的开始。有些HTTP版本,比如HTTP/1.1,要求有效的请求或相应报文中必须包含特定的首部。
实体的主体部分(entity-body)
实体的主体部分包含一个由任意数据组成的数据块。并不是所有的报文都包含实体的主题部分,有时,报文只是以一个
CRLF
结束。
起始行
请求行
包含了一个方法和一个请求URL,请求行中还包含HTTP的版本,在HTTP/1.0之前,并不要求请求行中包含HTTP版本号。
响应行
包含HTTP版本,数字状态码,以及描述操作状态的文本形式的原因短语。
方法
常用的HTTP方法有以下7种,注意,有些方法的请求报文中有主体,有的则没有。
状态码
通过三位数字代码对不同状态码进行分类,200到299之间的状态码表示成功。300到399之间的代码表示资源已经被移走了。400到499之间的代码表示客户端的请求出错了。500到599之间的代码表示服务器出错了。
原因短语
原因短语和状态码是成对出现的。原因短语是状态码的可读版本,应用程序开发者将其传送给用户,用以说明在请求期间发生了什么情况。
HTTP规范并没有提供任何硬性规定,要求原因短语以何种形式出现。
首部
首部分类
HTTP规范定义了几种首部字段。应用程序也可以随意发明自己所用的首部。HTTP首部可以分为以下几类。
通用首部
既可以出现在请求报文中,也可以出现在响应报文中。
请求首部
提供更多有关请求的信息。
响应首部
提供更多有关响应的信息。
实体首部
描述主题的长度和内容,或者资源自身。
扩展首部
规范中没有定义的新首部。
常见的首部实例
首部延续行
将长的首部行分为多行可以提高可读性,多出来的每行前面至少要有一个空格或制表符(tab)
例如:
HTTP/1.0 200 OKContent-Type: image/gifContent-Length: 8572Server: Test ServerVersion 1.0
在这个例子中,Server 首部的值Test Server Version 1.0
被划分成了多个延续行。