Otro argumento en contra de cerrar el OutputStream
. Mira este servlet. Lanza una excepción. La excepción se asigna en web.xml a un JSP de error:
package ser;
import java.io.*;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
@WebServlet(name = "Erroneous", urlPatterns = {"/Erroneous"})
public class Erroneous extends HttpServlet {
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.setContentType("text/html;charset=UTF-8");
PrintWriter out = resp.getWriter();
try {
throw new IOException("An error");
} finally {
// out.close();
}
}
}
El archivo web.xml contiene:
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<session-config>
<session-timeout>
30
</session-timeout>
</session-config>
<error-page>
<exception-type>java.io.IOException</exception-type>
<location>/error.jsp</location>
</error-page>
</web-app>
Y el error.jsp:
<%@page contentType="text/html" pageEncoding="UTF-8" isErrorPage="true"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Error Page</title>
</head>
<body>
<h1><%= exception.getMessage()%></h1>
</body>
</html>
Cuando carga /Erroneous
en el navegador, ve la página de error que muestra "Un error". Pero si anula el comentario de la out.close()
línea en el servlet anterior, vuelve a implementar la aplicación y vuelve /Erroneous
a cargar , no verá nada en el navegador. No tengo ni idea de lo que está pasando realmente, pero supongo queout.close()
evita el manejo de errores.
Probado con Tomcat 7.0.50, Java EE 6 usando Netbeans 7.4.
close()
que no hace nada. Lo que debe hacer es cerrar todos los recursos que se puedan cerrar.