作者:国民男神-权志龙 | 来源:互联网 | 2023-07-15 19:41
设置数据Response基类提供了data方法用于设置响应数据。response()->data($data);json()->data($data);不过需要注意的是data方法设置的只
设置数据
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,
]);