1

私はEclipsejunoを使用しています。ビルドパスにmysql-connector-java-5.1.22-bin.jarがあり、mysqlデータベースへのDB接続を確立しようとしています。これが私のコードです

public Connection getConnectionToDB() {
    try {
        Class.forName(driver);
        Connection con = DriverManager.getConnection(url + dbName,
                userName, password);
        return con;
    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}

私がそれをデバッグしたとき、私は問題が次の場所にあることを発見しました:

Class.forName(driver);

私もそれを次のように置き換えてみました:

Class.forName(driver).newInstance();

この行で、例外が発生し、次の例外がスローされます。

java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1676)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1521)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at main.jdbc.BaseJdbc.getConnectionToDB(BaseJdbc.java:18)
at main.jdbc.UserDriverJdbc.queryUserById(UserDriverJdbc.java:15)
at main.drivers.UserDriver.findUserById(UserDriver.java:50)
at main.drivers.UserDriver.isLoginValid(UserDriver.java:56)
at main.controllers.LoginController.doPost(LoginController.java:33)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641)
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.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:164)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.__invoke(StandardHostValve.java:164)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:166)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)
4

5 に答える 5

2

答えを見つけるのはかなり難しいですが、私はそれを理解しています。もちろん、クラスパスの問題でした。

このような問題に遭遇し、Eclipse内でそれを解決しようとした場合は、次のURLにアクセスしてください。

Eclipse->ウィンドウ->設定->Java->ビルドパス->クラスパス

を追加します

「mysql-connector-java-5.1.22-bin.jar」

新しい変数として。好きな名前を付けてください。お役に立てれば。

于 2012-10-17T19:12:03.017 に答える
0

プロジェクトに適切なライブラリと jar ファイルがロードされていることを確認する必要があります。postgresql を使っているとき、私はこれをよく扱いました。jarファイルが足りないだけだと思います。

于 2012-10-16T17:33:21.980 に答える
0

netbeans を使用している場合は、次の手順を実行します: アプリケーションに移動>>>ライブラリ>> jar を追加 (右クリック)>> "mysql-connector-java-5.1.22-bin.jar"

于 2017-07-16T08:16:05.633 に答える