Ola pessoal, sou novo nessa área e estou apanhando muito disso, faz 3 dias que estou procurando a solução e não acho.
Estou tentando criar um data source para conectar em um Mysql dentro do tomcat, mas a única coisa que consigo é:
Ocorreu um erro em: org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class ‘’ for connect URL ‘null’
Aparentemente, ele não consegue pegar a url que está dentro do arquivo “server.xml”.
versão do Tomcat: 5.5.20
versão do Mysql: 5.0.22
Estou postando os codigos que ahuda né??
web.xml
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">
<resource-ref>
<res-ref-name>jdbc/address</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
server.xml
<?xml version="1.0" encoding="UTF-8"?>
<Server>
<Listener className="org.apache.catalina.core.AprLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
<Listener className="org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
<GlobalNamingResources>
<Environment
name="simpleValue"
type="java.lang.Integer"
value="30"/>
<Resource
auth="Container"
description="User database that can be updated and saved"
name="UserDatabase"
type="org.apache.catalina.UserDatabase"
pathname="conf/tomcat-users.xml"
factory="org.apache.catalina.users.MemoryUserDatabaseFactory"/>
<Resource
name="jdbc/address"
type="javax.sql.DataSource"
password="root"
driverClassName="com.mysql.jdbc.Driver"
maxIdle="2"
maxWait="5000"
username="root"
url="jdbc:mysql://localhost:3306/address"
maxActive="4"/>
</GlobalNamingResources>
<Service
name="Catalina">
<Connector
port="8080"
redirectPort="8443"
minSpareThreads="25"
connectionTimeout="20000"
maxSpareThreads="75"
maxThreads="150">
</Connector>
<Connector
port="8009"
redirectPort="8443"
connectionTimeout="-1"
protocol="AJP/1.3">
</Connector>
<Engine
defaultHost="localhost"
name="Catalina">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"/>
<Host
appBase="webapps"
name="localhost">
<Context
path="/WebApplication3"
reloadable="true">
<Resource
auth="Container"
name="jdbc/address"
type="javax.sql.DataSource"/>
</Context>
</Host>
</Engine>
</Service>
</Server>
e a jsp que estou tentando obter a conexão:
<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@page import="java.sql.*, javax.sql.*, javax.naming.*"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Uso de DataSources</title>
</head>
<body>
<h1>Usando DataSource</h1>
<%
javax.sql.DataSource ds=null;
Connection conn=null;
ResultSet result=null;
Statement stmt=null;
ResultSetMetaData rsmd=null;
try
{
Context context = new InitialContext();
Context envCtx= (Context) context.lookup("java:comp/env");
ds=(DataSource)envCtx.lookup("jdbc/address");
if (ds != null)
{
conn=ds.getConnection();
stmt=conn.createStatement();
result=stmt.executeQuery("select * from addressList");
}
else
{
out.write("esta nulo");
}
}catch(Exception e)
{
out.write("Ocorreu um erro em: "+e);
}
int columns=0;
try
{
if (rsmd!=null){
rsmd=result.getMetaData();
columns=rsmd.getColumnCount();}
else
System.out.println("esta nulo");
}catch (SQLException e)
{
System.out.println("Ocorreu um erro "+e);
}
%>
</table>
</body>
</html>
A linha que está ocorrendo o erro é: conn=ds.getConnection();
pois retorna null na url do banco.
so observações: a minha base de dados é address e a tabela é addresslist
Obrigado!!