You indeed don't need to do so. Thumb rule: if you didn't open it yourself, you don't need to close it yourself. If it was for example a new FileOutputStream("c:/foo.txt")
then you obviously need to close it yourself.
Reasons that some people still do it are just to ensure that nothing more will be written to the stream. If it would ever happen, this will cause an IllegalStateException
in the appserver logs, but this wouldn't affect the client. This is also an easier debug to spot the potential problems in the request-response chain which you wouldn't see at first glance.
Another reason which you see among starters is that they just wanted to prevent that more stuff is written into the response. You see this often when JSP incorrectly plays a role in the response. They just swallow the IllegalStateException
s and ignore them further. Needless to say that this particular purpose is bad.