soy nuevo en esto de la programación web con servlets y me ha surgido un problema con el metodo sendRedirect de HttpServletResponse, vereis, tengo una aplicación web con la siguiente estructura:
-webapps(tomcat)
|-aplicacion1
|-WEB-INF
|-src
| |-IndexServlet.java
| |-InicioServlet.java
|-lib
| |-mysql.connector.jar
|-web.xml
esta estructura se corresponde con una aplicación de prueba que estoy creando, en ella esta el servlet IndexServlet en el que implemento los metodos doGet y doPost, cuando se accede al metodo doGet el servlet envía una salida html al cliente con una pagina web que contiene un formulario para iniciar sesión en el sistema, este formulario es enviado a su vez a este mismo servlet mediante post, en el metodo doPost recojo los datos de autenticación y realizo la consulta a la bbdd mysql, en el caso de que el login sea correcto redirijo al usuario al servlet InicioServlet mediante response.sendRedirect("/InicioServlet") y ahí es donde surge el proble pues en lugar de redirigir a http://host:8080/aplicacion1/InicioServlet redirige a http://host:8080/InicioServlet. ¿No se supone que el contexto de IndexServlet es /aplicacion1?? Estoy haciendo algo mal?? A ver si alguien me puede echar una manita con el tema, de antemano gracias y un saludo.
A continuación muestro el código de IndexServlet:
Código PHP:
Ver original
import java.io.*; import java.sql.*; import javax.Servlet.*; import javax.HttpServlet.*; public class IndexServlet extends HttpServlet { private static final long serialVersionUID = 1L; private Connection conn; public IndexServlet() { super(); } public void init(ServletConfig config) throws ServletException { super.init(config); String dbhost,dbname,dbuser,dbpass; dbhost=config.getInitParameter("host"); dbname=config.getInitParameter("database"); dbuser=config.getInitParameter("dbuser"); dbpass=config.getInitParameter("dbpass"); try{ Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://"+dbhost+"/"+dbname,dbuser,dbpass); } catch(ClassNotFoundException e){ e.printStackTrace(); throw new UnavailableException(e.getMessage()); } catch(SQLException e){ e.printStackTrace(); throw new UnavailableException(e.getMessage()); } } public void destroy() { // TODO Auto-generated method stub try{ conn.close(); } catch(SQLException e){ e.printStackTrace(); } } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub enviarPaginaHtml(response,false); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub HttpServletRequest req = request; HttpServletResponse res = response; String user, pass; user = req.getParameter("user"); pass=req.getParameter("pass"); String query="select cdg from usuario where descripcion='"+user+"'"+ "and pass='"+pass+"'"; try{ Statement stm = conn.createStatement(); ResultSet res1 = stm.executeQuery(query); // Si los datos de acceso eran correctos String cdg = res1.getString(1); HttpSession session = request.getSession(true); session.setAttribute("user",cdg); res.sendRedirect("InicioServlet"); } // si la validacion no ha sido correcta else{ enviarPaginaHtml(res,true); } } catch(SQLException e){ e.printStackTrace(); res.sendRedirect("IndexServlet"); } } public void enviarPaginaHtml(HttpServletResponse res,boolean error) throws ServletException,IOException { res.setContentType("text/html"); PrintWriter out = res.getWriter(); out.println("<!DOCTYPE html PUBLIC \"-//W3C//DTD " + "XHTML 1.0 Strict//EN\" \"http://www.w3.org" + "/TR/xhtml1/DTD/xhtml1-strict.dtd\">"); out.println("<html><head><title>Aplicación 1 - Iniciar sesión</title></head>"); out.println("<body><form name='frm-login' action='/IndexServlet' method='post'>"); out.println("<h2>Iniciar sesión</h2>"); if(error){ out.println("<div style='color: red; font-size: 10px; font-weight: bold'>"); out.println("El usuario y/o contraseña introducidos no son correctos"); out.println("</div>"); } out.println("<table align='center' border='0' cellpadding='0'>"); out.println("<tr><td>Usuario:</td><td><input type='text' name='user' size='15' "+ "value='' /></td></tr>"); out.println("<tr><td>Contraseña:</td><td><input type='password' name='pass' size='15' "+ "value='' /></td></tr>"); out.println("<tr><td colspan='2'><input type='submit' name='enviar' value='Enviar' /></td></tr>"); out.println("</table>"); out.println("</form>"); out.println("</body></html>"); out.close(); } }
y aqui el descriptor de despliegue por si el problema tiene que ver con este
Código XML:
Ver original
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>aplicacion1</display-name> <welcome-file-list> <welcome-file>IndexServlet</welcome-file> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <servlet> <description>Servlet que realiza el login de usuarios en el sistema</description> <display-name>IndexServlet</display-name> <servlet-name>IndexServlet</servlet-name> <servlet-class>IndexServlet</servlet-class> <init-param> <description>Host de la base de datos</description> <param-name>host</param-name> <param-value>localhost</param-value> </init-param> <init-param> <description>Nombre de la base de datos</description> <param-name>database</param-name> <param-value>test</param-value> </init-param> <init-param> <description>Usuario de la base de datos</description> <param-name>dbuser</param-name> <param-value>root</param-value> </init-param> <init-param> <description>Contraseña de la base de datos</description> <param-name>dbpass</param-name> <param-value>mysqladm</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>IndexServlet</servlet-name> <url-pattern>/IndexServlet</url-pattern> <url-pattern>/index</url-pattern> <url-pattern>/index.*</url-pattern> </servlet-mapping> <servlet> <description>Servlet que gestiona el menu de opciones de la aplicacion</description> <display-name>InicioServlet</display-name> <servlet-name>InicioServlet</servlet-name> <servlet-class>InicioServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>InicioServlet</servlet-name> <url-pattern>/InicioServlet</url-pattern> <url-pattern>/inicio</url-pattern> <url-pattern>/inicio.*</url-pattern> </servlet-mapping> </web-app>