Не удается создать драйвер JDBC класса ''для connect URL 'null': я не понимаю это исключение

почему он сказал null URL и дает пустой '' класс в исключении, когда я предоставил URL базы данных ?

Я пытаюсь подключиться к derby база данных через сервлет при использовании Tomcat. Когда сервлет запускается, я получаю следующие исключения:

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'

at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1452)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044)

at servlets.servlet_1.doGet(servlet_1.java:23) // ---> Marked the statement in servlet

at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:964)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.NullPointerException
at sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507)
at sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476)
at sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307)
at java.sql.DriverManager.getDriver(DriverManager.java:253)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1437)
... 24 more

сервлет :

package servlets;

import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.servlet.http.*;
import javax.servlet.*;
import javax.sql.DataSource;

public class servlet_1 extends HttpServlet{

@Override 
public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException {
    try {
       // String queryString = request.getQueryString();
        System.out.println("!!!!!!!!!!!!!!!!!!!");
        Context initContext = new InitialContext();
        Context envContext = (Context)initContext.lookup("java:comp/env");
        DataSource ds = (DataSource)envContext.lookup("jdbc/PollDatasource");
        Connection connection = ds.getConnection(); // -->LINE 23
        String sqlQuery = "select * from PollResult";
        PreparedStatement statement = connection.prepareStatement(sqlQuery);
        ResultSet set = statement.executeQuery();
        System.out.println("after the final statement");
    }catch(Exception exc) {
        exc.printStackTrace();
    }
}

}

какое это исключение ? По какой причине я получаю это исключение ?

я добавил следующий тег context.xml из-котяра :

<Resource name="jdbc/PollDatasource" auth="Container" type="javax.sql.DataSource"
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
url="jdbc:derby://localhost:1527/poll_database;create=true"
username="suhail" password="suhail"
maxActive="20" maxIdle="10" maxWait="-1" />

и в web.xml :

   <resource-ref>
<description>my connection</description>
<res-ref-name>jdbc/PollDatasource</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>

где я делаю ошибку ?

изображение, которое показывает URL базы данных..

enter image description here

Примечание: после ответа @Bryan Pendleton я изменил драйвер на org.apache.derby.jdbc.ClientDriver но я получаю то же самое исключение.

11 ответов


Я не вижу ничего явно плохого, но, возможно, другой подход может помочь вам отладить его?

вы можете попробовать указать источник данных в контексте каждого приложения вместо глобального tomcat.

вы можете сделать это, создав src/main/webapp/META-INF/context.xml (я предполагаю, что вы используете стандартную структуру каталогов maven - если нет, то папка META-INF должна быть братом вашего каталога WEB-INF). Содержание META-INF / context.xml-файл будет выглядеть примерно так:

<?xml version="1.0" encoding="UTF-8"?>

<Context path="/myApp" docBase="myApp"
   crossContext="true" reloadable="true" debug="1">

<Resource name="jdbc/PollDatasource" auth="Container"
          type="javax.sql.DataSource" driverClassName="org.apache.derby.jdbc.ClientDriver"
          url="jdbc:derby://localhost:1527/poll_database;create=true"
          username="suhail" password="suhail" maxActive="20" maxIdle="10" maxWait="-1"/>
</Context>

очевидно, что путь и docBase должны соответствовать конкретным деталям вашего приложения.

используя этот подход, вам не нужно указывать детали источника данных в контексте Tomcat.XML-файл. Хотя, если у вас есть несколько приложений, говорящих с одной и той же базой данных, ваш подход имеет больше смысла.

во всяком случае, дайте этому вихрь и посмотрите, имеет ли это значение. Это может дать нам подсказка о том, что происходит не так с вашим подходом.


исправления:

  1. используйте правильное имя класса драйвера для вашей среды: если вы используете сервер Derby вне процесса, то вы хотите ClientDriver (и должны использовать derbyclient.jar), имя хоста и порт и т. д. Если вы хотите сервер Derby в процессе, то вы хотите derby.jar, EmbeddedDriver и URL-адрес, соответствующий встроенной базе данных.

  2. положить jar-файл драйвера только в Tomcat это lib/ справочник.

  3. ничего не положить в Tomcat это conf/context.xml: на самом деле для этого нет причин. Вместо этого используйте META-INF/context.xml для определения <Resource>.

ошибка "Cannot create JDBC driver of class '' for connect URL 'null' обычно происходит потому, что драйвер JDBC находится не в нужном месте (или в слишком многих местах, таких как Tomcat's , но и в веб-приложение по ). Пожалуйста, убедитесь, что у вас есть правильный файл jar драйвера в нужном месте.


эти две вещи не совпадают:

driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
url="jdbc:derby://localhost:1527/poll database;create=true"

Если вы используете EmbeddedDriver, Ваш URL-адрес не должен содержать синтаксис сети.

и наоборот, если вы используете сетевой синтаксис, вам нужно использовать ClientDriver.

http://db.apache.org/derby/docs/10.8/getstart/rgsquck35368.html


я получил эту проблему, потому что я положил context.xml в неправильный путь:

./src/main/resources/META-INF/context.xml

правильный путь был:

./src/main/webapp/META-INF/context.xml

Если вы используете Eclipse, вы должны изменить контекст.xml из проекта сервера, созданного в обозревателе пакетов eclipse. При использовании Tomcat в Eclipse и это только один действительный, остальные игнорируются или overwriten


в моем случае я решил проблему редактирования [tomcat] / Catalina/localhost / [mywebapp_name].xml вместо META-INF/context.XML.


Context envContext = (Context)initContext.lookup("java:comp/env");

нет:Context envContext = (Context)initContext.lookup("java:/comp/env");


вы пытались указать ресурс только в context.xml

<Resource name="jdbc/PollDatasource" auth="Container" type="javax.sql.DataSource"
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
url="jdbc:derby://localhost:1527/poll_database;create=true"
username="suhail" password="suhail"
maxActive="20" maxIdle="10" maxWait="-1" />

и удалить С web.xml?

в одном проекте я видел конфигурацию без на web.xml и это сработало.

это обоснованная догадка, но я думаю <resource-ref> декларация JNDI ресурс с именем jdbc/PollDatasource на web.xml может переопределить объявление ресурса с тем же именем в context.xml и декларации web.xml отсутствует как driverClassName и url следовательно, NPEs для этих свойств.


Если вы используете встроенный драйвер, connectString-это просто

jdbc:derby:databaseName 

(С такими параметрами, как; create=true; user=xxx и т. д.).

Если вы используете драйвер клиента, строку подключения можно оставить как есть, но если замена драйверов не дает никакого результата... извините за вопрос, но вы на 100% уверены, что запустили сетевой сервер Derby в соответствии с дерби учебник?


У меня была аналогичная проблема с использованием Tomcat против Oracle. Я!--1-->сделал есть контекст.xml в каталоге META-INF, на диске. Однако этот файл не отображался в проекте eclipse. Простое нажатие на обновление F5 и контекст.появился xml-файл, и eclipse опубликовал его. Все прошло мимо этого. Надеюсь, это кому-то поможет.

попробуйте нажать F5 в eclipse


проблема также может возникнуть из-за отсутствия SQL driver в каталоге установки Tomcat.

Я должен был иметь mysql-connector-java-5.1.23-bin.jar на .

https://dev.mysql.com/downloads/connector/j/