Ver Mensaje Individual
  #1 (permalink)  
Antiguo 20/03/2012, 18:32
ollomol
 
Fecha de Ingreso: marzo-2012
Ubicación: Galicia
Mensajes: 27
Antigüedad: 12 años, 9 meses
Puntos: 0
No consigo empezar (Conexión tomcat-mysql)

Hola, estoy empezando con el java, tomcat, mysql con el objetivo de aprender a hacer una web con accceso a base de datos pero me estoy tropezando con una piedra que no me permite ni siquiera arrancar. Os ruego que me echeis una mano.

Mi context.xml:

<Context path="/bdacademia" docBase="bdacademia"
debug="5" reloadable="true" crossContext="true">
<Resource name="jdbc/bdacademia" auth="Container"
type="javax.sql.DataSource" maxActive="100"
maxIdle="30" maxWait="10000" username="root"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/bdacademia"/>
</Context>

Mi web.xml:

<web-app xmlns="http://java.sun.com/xml/ns/j2ee" version="2.4"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://java.sun.com/dtd/web-app_2_3.dtd">

<servlet>
<servlet-name>AccesoBD</servlet-name>
<servlet-class>AccesoBD</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>AccesoBD</servlet-name>
<url-pattern>/AccesoBD</url-pattern>
</servlet-mapping>


<resource-ref>
<res-ref-name>jdbc/bdacademia</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

</web-app>

Mi archivo accesobd.java

import javax.naming.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.sql.*;
import java.io.*;
import java.sql.*;
public class AccesoBD extends HttpServlet {
private DataSource fuenteDatos = null;
public void init(ServletConfig conf)
throws ServletException
{
super.init(conf);
Context ctx;
try{
ctx = new InitialContext();
fuenteDatos = (DataSource)
ctx.lookup("java:comp/env/jdbc/bdAcademia");
}
catch (NamingException e){
e.printStackTrace();
}
}

public void doGet(HttpServletRequest req,
HttpServletResponse res)
throws ServletException, IOException {
res.setContentType("text/html");
Connection conexion= null;
synchronized (fuenteDatos)
{
try{

conexion= fuenteDatos.getConnection();
}
catch (SQLException e) {
e.printStackTrace();
}
}
PrintWriter out= res.getWriter();
out.println("<html>");
out.println("<body>");
out.println("<h1>¡Conexión realizada¡</h1>");
out.println("</body>");
out.println("</html>");
try {
conexion.close();
}
catch (SQLException e) {
e.printStackTrace();
}
}

public void doPost(HttpServletRequest req,
HttpServletResponse res)
throws ServletException, IOException {
doGet(req, res);
}
}

Dentro de index.html:

...
<form action="AccesoBD" method="post">
<label for="usuario"> Usuario </label>
<br/>
<input type="text" name="usuario" value="" />
<br/>
<br/>
<label for="contrasenha"> Contrase&ntildea </label>
<br/>
<input type="password" name="contrasenha" value="" />
<br/>
<br/>
<br/>
<input type="submit" name="aceptar" value="ACEPTAR" />
&nbsp;
<input type="reset" name="limpiar" value="LIMPIAR" />
<br/>
<br/>
<br/>
</form>
...

Trabajo con windows vista, tomcat 6.0.35, xampp 2.5
El tomcat funciona (la dirección localhost:8080/academia/index.html muestra la página) pero cuando intenta la conexión a la bd me da el siguiente error:

Estado HTTP 500 -

--------------------------------------------------------------------------------

type Informe de Excepción

mensaje

descripción El servidor encontró un error interno () que hizo que no pudiera rellenar este requerimiento.

excepción

java.lang.NullPointerException
AccesoBD.doGet(AccesoBD.java:28)
AccesoBD.doPost(AccesoBD.java:63)
javax.servlet.http.HttpServlet.service(HttpServlet .java:637)
javax.servlet.http.HttpServlet.service(HttpServlet .java:717)


nota La traza completa de la causa de este error se encuentra en los archivos de diario de Apache Tomcat/6.0.35.

---------------------------

Estoy desesperado porque no encuentro la manera de arreglarlo y ni siquiera puedo empezar a trabajar, a aprender. ¿Qué está mal?

Muchísimas gracias, a ver si me podeis echar un cable.