同福

做个web框架(13)——响应对象TFResponse(一)响应状态、响应数据类型、响应数据长度【20201108】

介绍

介绍

今天我们来讲讲响应对象TFResponse,它也是系统级别的对象,它负责视图的输出。也就是说用户在浏览器上看到的一些网页内容都是通过TFResponse响应对象输出出来的。输出数据包括很多属性,如:响应数据类型、响应数据大小、服务器信息、服务器指令等等。

响应对象TFResponse

首先我们先建立TFResponse这个响应对象,程序文件保存在System/TFResponse.inc.php。

4a34709da332487a.jpg

响应头

响应头和请求头相似的、相对的。请求头是浏览器组织起来的数据,浏览器会将请求头发送给服务器。而响应头是服务器组织起来的数据,服务器会根据浏览器送过来的请求头找到对应的请求资源,并把资源数据的信息组织成响应头送回给浏览器。

下面给出一个完整的响应头信息示例:

200 OK HTTP/1.1
Connection: keep-alive
Content-Type: text/html; charset=UTF-8
Date: Sun, 08 Nov 2020 10:50:09 GMT
Server: nginx
Transfer-Encoding: chunked
X-Powered-By: PHP/7.4.6

响应状态

在响应头的第一行会有一个三位数字和一个短语,这个就是服务器响应用户请求的状态信息。三位数字表示响应状态码,而短语则是响应状态的文字信息。举例来说:响应状态信息“200 OK”就表示用户请求的资源找到了且正常下载下来了,后面的短语也很直观地反应了这个结果。

响应状态对照表

响应状态有很多,下面福哥给出一个比较全面的状态信息对照给大家:

100Continue
101Switching Protocols
102Processing
200OK
201Created
202Accepted
203Non-Authoritative Information
204No Content
205Reset Content
206Partial Content
207Multi-Status
300Multiple Choices
301Moved Permanently
302Move temporarily
303See Other
304Not Modified
305Use Proxy
306Switch Proxy
307Temporary Redirect
400Bad Request
401Unauthorized
402Payment Required
403Forbidden
404Not Found
405Method Not Allowed
406Not Acceptable
407Proxy Authentication Required
408Request Timeout
409Conflict
410Gone
411Length Required
412Precondition Failed
413Request Entity Too Large
414Request-URI Too Long
415Unsupported Media Type
416Requested Range Not Satisfiable
417Expectation Failed
421Too Many Connections
422Unprocessable Entity
423Locked
424Failed Dependency
425Unordered Collection
426Upgrade Required
449Retry With
451Unavailable For Legal Reasons
500Internal Server Error
501Not Implemented
502Bad Gateway
503Service Unavailable
504Gateway Timeout
505HTTP Version Not Supported
506Variant Also Negotiates
507Insufficient Storage
509Bandwidth Limit Exceeded
510Not Extended
600Unparseable Response Headers

设置响应状态

响应状态必须在响应头第一行,在PHP语言里可以通过内建的header函数设置响应头信息,通过header设置响应状态信息的方法如下:

header("HTTP/1.1 200 OK");

数据类型

在响应头里我们需要告诉浏览器用户请求的资源是什么数据类型。数据类型很好理解,通俗地说就是:用户打开的是一个网页?一张图片?一个MP3?还是一段视频?这些格式就是我们说的数据类型了。举例来说:JPG格式的图片对应的数据类型就是“image/jpeg”,MP3音乐对应的数据类型就是“audio/mpeg”,普通网页就是“text/html”。

MIME类型

数据类型通过一个标准格式描述,这种格式称之为MIME类型,专门用于HTTP协议的响应头的数据类型。下面福哥整理了一些常用的数据类型和文件扩展名的对照给大家:

html,text/html
htm,text/html
txt,text/plain
json,application/json
js,text/javascript
css,text/css
jpg,image/jpeg
jpeg,image/jpeg
pjpeg,image/jpeg
png,image/png
gif,image/gif

大家可能已经发现了,很多不同的扩展名对应的MIME类型是一样的,这说明了这些有着一样MIME类型的文件它们的结构是一样的,可以通过一样的工具打开或编辑或运行。

数据长度

响应头里需要告诉浏览器用户请求的资源有多大,这样浏览器才知道需要下载多少数据才能下载完成。这个数据长度需要显性地告知浏览器,且需要在响应体里给出这样多的数据给浏览器才行。

除了显性告知浏览器数据长度外,还有一种方式让浏览器知道如何下载资源内容,就是使用chunked编码方式。

chunked

所谓chunked编码方式就是将资源内容一块一块地推送给浏览器,每一块数据推送之前都会告知这一块数据的长度,而每一块数据不会太长。

这一块一块的数据的长度通过一个16进制数字表示,在数据长度后面用一个CRLF换行符表示块长度结束,在CRLF后面就是块数据了,块数据的长度必须和前面的数字声明的一样。

下面举例:

15(十进制21)
福哥,你真棒!(这一段文字长度也是21)
2a(十进制42)
我要和跟着福哥好好学习编程~~

总结

今天福哥给大家讲解了关于web请求的响应头的相关知识,童鞋们知道了响应头的响应状态是怎么回事了,童鞋们也了解了关于MIME类型的作用,童鞋们还明白了两种响应数据长度的不同,知道了chunked的原理。

下一课福哥要开始带着大家实现响应对象TFResponse的功能了,今天课上的知识童鞋们下去一定要好好研读哦~