56

データベース URL を指定したのに、 null URL と表示され、例外で空の ' ' クラスが返されるのはなぜですか?

Tomcat を使用しているときに、サーブレット経由で derby データベースに接続しようとしています。サーブレットが実行されると、次の例外が発生します。

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.xmlTomcatに次のタグを追加しました。

<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>
</resource-ref>

どこで間違いを犯していますか?

データベースの URL を示す画像。

ここに画像の説明を入力

注:@Bryan Pendletonによる回答の後、ドライバーをに変更しましたorg.apache.derby.jdbc.ClientDriverが、同じ例外が発生します。

4

11 に答える 11

37

明らかに間違っていることはわかりませんが、おそらく別のアプローチでデバッグするのに役立つでしょうか?

グローバルな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 [optional other attributes as required]>

<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 の context.xml ファイルでデータソースの詳細を指定する必要がなくなります。ただし、複数のアプリケーションが同じデータベースと通信している場合は、アプローチがより理にかなっています。

とにかく、これをぐるぐる回して、違いがあるかどうかを確認してください. あなたのアプローチの何が問題なのかについての手がかりを私たちに与えるかもしれません.

于 2012-07-21T00:42:21.090 に答える
11

いくつかの修正:

  1. 環境に適したドライバー クラス名を使用します。アウト プロセスの Derby サーバーを使用している場合は、ClientDriver (および derbyclient.jar を使用する必要があります)、ホスト名、ポートなどが必要です。 Derby サーバーを処理する場合は、derby.jar、EmbeddedDriver、および組み込みデータベースに適した URL が必要です。

  2. ドライバーの JAR ファイルは、Tomcat のディレクトリにのみ配置してくださいlib/

  3. Tomcat には何も入れないでくださいconf/context.xml。特に理由はありません。代わりに、webappMETA-INF/context.xmlを使用して<Resource>.

このエラー"Cannot create JDBC driver of class '' for connect URL 'null'は通常、JDBC ドライバーが適切な場所にない (または、Tomcat のlib/ディレクトリだけでなく webapp のWEB-INF/lib/ディレクトリなど、あまりにも多くの場所にある) ために発生します。正しいドライバ JAR ファイルが正しい場所にあることを確認してください。

于 2012-07-22T21:23:43.673 に答える
7

次の 2 つのことは一致しません。

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

于 2012-07-17T17:53:39.590 に答える
7

context.xml間違ったパスに入れたため、この問題が発生していました:

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

正しいパスは次のとおりです。

./src/main/webapp/META-INF/context.xml
于 2015-12-01T11:50:00.353 に答える
3

Eclipse を使用している場合は、Eclipse パッケージ エクスプローラーで作成されたサーバー プロジェクトから context.xml を変更する必要があります。Eclipse で tomcat を使用する場合、それが有効な唯一のものであり、他のものは無視されるか上書きされます

于 2013-11-25T09:50:47.717 に答える
2

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

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

于 2012-07-17T06:02:21.243 に答える
1

リソースのみを指定しようとしましたか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" />

<resource-ref>からセクションを削除しweb.xmlますか?

あるプロジェクトでは、<resource-ref>セクションのない構成を見たことがありますが、うまくいきましweb.xmlた。

これは経験に基づいた推測ですが、inという名前のリソースの宣言は in の同じ名前のリソースの<resource-ref>宣言をオーバーライドする可能性があり、 in の宣言には両方が欠落しているため、そのプロパティの NPE が欠落していると思います。JNDIjdbc/PollDatasourceweb.xmlcontext.xmlweb.xmldriverClassNameurl

于 2012-07-19T14:09:36.763 に答える
0

組み込みドライバーを使用している場合、connectString は単に

jdbc:derby:databaseName 

(オプションは;create=true;user=xxx など)。

クライアント・ドライバーを使用している場合、接続文字列はそのままにしておくことができますが、ドライバーを変更しても結果が得られない場合は... 質問をお許しください。Derby チュートリアルに従って Derby Network Server を開始したことを 100% 確信していますか? ?

于 2012-07-20T14:48:52.690 に答える