-
Notifications
You must be signed in to change notification settings - Fork 40.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improve response message on DecodingException #18815
Comments
On second thought, I wonder if this is the right place to fix this. The Taking a look at DefaultErrorAttributes it does seem to write only the message of the top level exception. Is there some room for improvement there @bclozel to also write the cause, or is there a reason why the cause isn't included? |
Spring Boot is providing configuration properties for writing the actual exception class ( I assume this is because we don't want to expose information about application internals by default, and we're leaving that choice to developers. |
@rstoyanchev thanks for your answer! Those were some of my thoughts as well when browsing through the code. As far as I can tell, there are two main ways to improve this:
|
@PyvesB Are you sure you're using Spring Boot 2.2? The error message should include the I'm wondering if including the cause by default would not leak important internal information about the application. |
@bclozel at the time of opening the issue, Spring Boot 2.2 was not yet released. So I did check out in the latest milestone, but took an error message from our production servers. Here's what it looks like with the latest:
Only I think a middle ground has to be found, where the user is not confusingly in the dark ("Failed to read HTTP message"), but has some indication of why his request is invalid. |
I've transferred this on the Spring Boot tracker so we can consider an enhancement here. |
I think including the top level message isn't all that different from including the root cause message, and arguably both could have been included, but starting to do that at this stage is almost certainly going to cause a surprise somewhere. Having the option to enable that seems reasonable to me. It is already possible by including the full stack trace, so this would be a sort of in-between option. |
The Spring Boot team has been discussing this and we're not 100% sure yet about that change.
I'll report back here with my findings. |
Whatever sample cases you find, I'm sure some will look good and some less so. I don't know if that helps to decide. Either way Boot already allows getting this information through the full stacktrace but to go there is to get too much and too implementation specific. To me this is more a question of how rather than if. It should be configurable somehow. It would feel odd if by contrast all exceptions had to be modified to ensure their top-level exception include messages from nested exceptions, when the exception already includes everything. Perhaps instead of another attribute for the root cause, it could be a property that effectively says, include all messages, not just the top one. |
Has anyone found a solution to this issue? I've started running into it and it is tough to debug bad requests with the default message, and the stack trace is annoyingly verbose for our frontend developers. A middle ground solution would be great. |
Closing as superseded, since Spring Framework now allows to customize this through |
Affects: 5.2.0
Hello,
When a
DecodingException
is thrown from a reactive handler chain, it is mapped to aServerWebInputException
, with a genericFailed to read HTTP message
reason:https://github.com/spring-projects/spring-framework/blob/d1aee0e8691c41753621332ff69b17be3f7c8ba2/spring-webflux/src/main/java/org/springframework/web/reactive/function/server/DefaultServerRequest.java#L73
As a consequence, all bad request bodies are similar, regardless of what caused them in the first place:
The client is not provided with any helpful message indicating why the request was unsuccessful, it's not even clear that this was caused by a failure to decode the body in the first place.
For example, when using a
AbstractJackson2Decoder
, theDecodingException
contains much more useful information, such as:Could such information be included as part of the Bad Request response?
Thanks for reading!
Pyves
The text was updated successfully, but these errors were encountered: