Response对象

生命周期

Response对象在系统中以单例模式存在,自收到客户端HTTP请求时自动创建,直至请求结束自动销毁。Response对象完全符合PSR7中的所有规范。

方法列表

getInstance()

用于获取当前请求实例。

  1. $response = Response::getInstance()

write

该方法用于向客户响应数据。

  1. $response->write('hello world');

writeJson

向客户端响应一个标准的json数据。

  1. $response->writeJson($statusCode = 200,$result = null,$msg = null)
  2. //{"code":200,"result":null,"msg":null}

redirect

该方法用于将请求重定向至指定的URL

  1. $response()->redirect("/newURL/index.html");

setCookie

向客户端设置一个Cookie,用法与原生的setCookie一致。

forward

将客户端请求做内部转发至新的URL。

  1. $response()->forward('/api2/index.html');

注意:该方法有别于redirect。forward是将请求做服务内部转发。

getSwooleResponse

用于获取原始的swoole_http_response实例。

end

结束对该次HTTP请求响应

isEndResponse

判断该次HTTP请求是否结束响应。

PSR-7规范Response对象中常用方法

withStatus

向客户端发送HTTP状态码。

  1. $response()->withStatus($statusCode);

注意:$statusCode必须为标准的HTTP允许状态码,具体请见Http Message中的Status对象。

withHeader

用于向HTTP客户端发送一个header。

  1. $response()->withHeader('Content-type','application/json;charset=utf-8');

Session()

该方法用于返回当前SessionResponse实例。注意,返回该实例的时候,不会自动执行session start。若有执行set方法,则会自动调用session start

  1. $response()->session()->set("test","value");