Response
对象提供了一系列方法用于设置响应参数,包括设置输出内容、状态码及header信息等,并且支持链式调用以及多次调用。
Response
基类提供了data
方法用于设置响应数据。
response()->data($data);
json()->data($data);
不过需要注意的是data
方法设置的只是原始数据,并不一定是最终的输出数据,最终的响应输出数据是会根据当前的Response
响应类型做自动转换的,例如:
json()->data($data);
最终的输出数据就是json_encode($data)
转换后的数据。
如果要获取当前响应对象实例的实际输出数据可以使用getContent
方法。
Response
基类提供了code
方法用于设置响应数据,但大部分情况一般我们是直接在调用助手函数的时候直接传入状态码,例如:
json($data,201);
view($data,401);
或者在后面链式调用code
方法是等效的:
json($data)->code(201);
除了
redirect
函数的默认返回状态码是302
之外,其它方法没有指定状态码都是返回200
状态码。
如果要获取当前响应对象实例的状态码的值,可以使用getCode
方法。
可以使用Response
类的header
设置响应的头信息
json($data)->code(201)->header(['Cache-control' => 'no-cache,must-revalidate']);
header
方法支持两种方式设置,如果传入数组,则表示批量设置,如果传入两个参数,第一个参数表示头信息名,第二个参数表示头信息的值,例如:
// 单个设置
header('Cache-control', 'no-cache,must-revalidate');
// 批量设置
header([
'Cache-control' => 'no-cache,must-revalidate',
'Last-Modified' => gmdate('D, d M Y H:i:s') . ' GMT',
]);
除了header
方法之外,Response
基类还提供了常用头信息的快捷设置方法:
方法名 | 作用 |
---|---|
lastModified |
设置Last-Modified 头信息 |
expires |
设置Expires 头信息 |
eTag |
设置ETag 头信息 |
cacheControl |
设置Cache-control 头信息 |
contentType |
设置Content-Type 头信息 |
除非你要清楚自己在做什么,否则不要随便更改这些头信息,每个Response
子类都有默认的contentType
信息,一般无需设置。
你可以使用getHeader
方法获取当前响应对象实例的头信息。
有些时候,响应输出需要设置一些额外的参数,例如:
在进行json
输出的时候需要设置json_encode
方法的额外参数,jsonp
输出的时候需要设置jsonp_handler
等参数,这些都可以使用options
方法来进行处理,例如:
json($data)
->options('json_encode_param',JSON_PRETTY_PRINT);
也可以支持传入数组作为参数:
jsonp($data)
->options([
'var_jsonp_handler' => 'callback',
'default_jsonp_handler' => 'jsonpReturn',
'json_encode_param' => JSON_PRETTY_PRINT,
]);
V5.1.5+
)V5.1.5+
版本开始,支持使用allowCache
方法动态控制是否需要使用请求缓存。
// 关闭当前页面的请求缓存
json($data)->code(201)->allowCache(false);
如果需要特别的自定义响应输出,可以自定义一个Response
子类,并且在控制器的操作方法中直接返回。又或者通过设置响应参数的方式进行响应设置输出。