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ña </label>
<br/>
<input type="password" name="contrasenha" value="" />
<br/>
<br/>
<br/>
<input type="submit" name="aceptar" value="ACEPTAR" />
<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.