-
Notifications
You must be signed in to change notification settings - Fork 196
Contents of response appears after exception is thrown #347
Comments
|
What about if the stream isn't seekable or if the output written is longer than the error page? I think maybe a better solution would be to create a new |
You're totally right. Unfortunately there's no easy way to create a new |
This would probably also be an issue with the FinalHandler. In my opinion, the The downside to this is if you need to be able to add custom headers, you cannot do so. One of my biggest gripes with expressive is actually the error handling. It's probably the least straight-forward system. Making more use of the middleware-pipeline for the error handling would be really great. It would also be a good way to solve this, as well as still allow custom headers. |
In my opinion, if an exception is thrown, it shouldn't re-use any existing Response: class UseEmptyDefaultResponseMiddleware
{
public function __invoke($req, $res, $next)
{
// Trigger Exception and use a new empty response
throw new \Exception('Page Not Found', 404);
}
} If you want to reuse the Response object and add headers, that is already covered: class ReuseCurrentResponseMiddleware
{
public function __invoke($req, $res, $next)
{
// Trigger error with a specific response
$res = $res->withHeader('X-Powered-By', 'Zend Expressive');
return $next($req, $res->withStatus(404), 'Page Not Found');
}
} |
I agree that it shouldn't reuse an existing response. However my question remains that shouldn't error handling be done via the error middleware? Seems weird to me to have two ways to do error handling. I can understand needing a FinalHandler, but in my opinion, that should really be a worst case scenario. Nothing should ever get to it unless even the error middleware fail to return a response (aka they are throwing exceptions for some reason). This is kind of how I would expect to see a template error handler implemented. This would allow modifying the response from that error handler if you put another middleware before it and did 'error' => [
'middleware' => [
\TemplateErrorHandler::class
],
'error' => true,
'priority' => -10000,
], |
There are two issues being discussed here:
The second is not what was originally reported, but a topic that came up during discussion of the issue; it is being resolved for version 1.1.0 via #396. The first, however, is not resolved, and should be. I'll work on a PR for this shortly. |
Using the skeleton project I changed
PingAction
to this:However, it appears that a new response isn't used to render the error page. The JSON that was written to the response before the exception was thrown still appears in the error page:
I'm happy to submit a PR, but I checked the
TemplatedErrorHandler
and it seemed like some of the behaviour using the original response was intentional?The text was updated successfully, but these errors were encountered: