Bonjour, je suis bloqué sur le tutorial suivant :
http://christophej.developpez.com/tu...ee/pooltomcat/
Voici l'erreur :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6 type Rapport d'état message Exception sur l'accès à la BDD org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' description Le serveur a rencontré une erreur interne (Exception sur l'accès à la BDD org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null') qui l'a empêché de satisfaire la requête.
Voici mon web.xml
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app> <display-name>TutoPool</display-name> <servlet> <servlet-name>TutoPool</servlet-name> <servlet-class>tutorial.TutoPool</servlet-class> </servlet> <servlet-mapping> <servlet-name>TutoPool</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <resource-ref> <description> reference a la ressource BDD pour le pool </description> <res-ref-name>jdbc/TutoPool</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref> </web-app>
Voici mon context.xml
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 <Context path="/TutoPool" reloadable="true" docBase="\TutoPool" > <Resource name="jdbc/TutoPool" auth="Container" type="javax.sql.DataSource"/> <ResourceParams name="jdbc/TutoPool"> <parameter> <name>username</name> <value>postgres</value> </parameter> <parameter> <name>password</name> <value>postgres</value> </parameter> <parameter> <name>driverClassName</name> <value>org.postgresql.Driver</value> </parameter> <parameter> <name>url</name> <value>jdbc:postgresql://127.0.0.1:5432/Hibernate</value> </parameter> </ResourceParams> </Context>
et ma servlet
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67 package tutorial; import java.io.*; import java.sql.*; import javax.naming.*; import javax.servlet.*; import javax.servlet.http.*; import javax.sql.*; public class TutoPool extends HttpServlet { private DataSource ds; //la source de données protected void doGet( HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); PrintWriter out = response.getWriter(); out.println("<html><head></head>"); out.println("<body>"); Connection con=null; Statement s=null; ResultSet rs=null; try { //récupération de la Connection depuis le DataSource con = ds.getConnection(); s = con.createStatement(); rs = s.executeQuery("SELECT * FROM contact"); while (rs.next()) { out.println(rs.getString("nom") + " "); out.println(rs.getString("prenom") + "<br/>"); } } catch (SQLException e) { response.sendError(500, "Exception sur l'accès à la BDD " + e); }finally { if (rs != null) { try { rs.close(); } catch (SQLException e) {} rs = null; } if (s != null) { try { s.close(); } catch (SQLException e) {} s = null; } if (con != null) { try { con.close(); } catch (SQLException e) {} con = null; } } out.println("</body>"); out.println("</html>"); out.close(); } public void init() throws ServletException { try { //récupération de la source de donnée Context initCtx = new InitialContext(); ds = (DataSource) initCtx.lookup("java:comp/env/jdbc/TutoPool"); } catch (Exception e) { throw new UnavailableException(e.getMessage()); } } }
enfin la configuration de mon projet :
Merci pour votre aide
Partager