質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.99%

  • Java

    12182questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • PostgreSQL

    868questions

    PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

  • Heroku

    633questions

    HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

  • Gradle

    101questions

    Gradleは、ビルド自動化ツールです。 ソフトウェアパッケージやドキュメント、 または実際に何か他の種類のプロジェクトの構築、テスト、公開、展開などを自動化が出来ます

GradleプロジェクトをHerokuへデプロイし、アクセスしたところ「java.lang.ClassNotFoundException: org.postgresql.Driver」がでてしまう

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 193

guremusu

score 3

GradleプロジェクトをHerokuへデプロイし、アクセスしたところ「java.lang.ClassNotFoundException: org.postgresql.Driver」がでてしまいます。

java.lang.ClassNotFoundException: org.postgresql.Driver
とのことなので、クラスパスの設定がうまくいっていないと思っているのですが、Gradle初心者のためどのようにしてクラスパスを通せるのかわかりません。
Eclipse上では「ビルドパス」「外部アーカイブの追加」を実施して「postgresql-42.1.4.jre7.jar」を追加しています。

初歩的な質問かもしれませんが、アドバイスなど頂けますと幸いです。
よろしくお願いいたします。

//プログラム(一部抜粋)
Connection db = null;
PreparedStatement ps;
ResultSet rs;
// PostgreSQL JDBC ドライバロード
try {
Class.forName("org.postgresql.Driver");
// PostgreSQL JDBC 接続
String dsn =
"postgres:XXXXX";
db = DriverManager.getConnection(dsn);
}catch (Exception e) {
// エラー処理
System.err.println("SQL failed.");
e.printStackTrace ();
}

build.grade
dependencies {
// This dependency is exported to consumers, that is to say found on their compile classpath.
api 'org.apache.commons:commons-math3:3.6.1'

// This dependency is used internally, and not exposed to consumers on their own compile classpath.
implementation 'com.google.guava:guava:23.0'

// Use JUnit test framework
testImplementation 'junit:junit:4.12'

compile group: 'commons-collections', name: 'commons-collections', version: '3.2'
compile group: 'javax.servlet', name: 'javax.servlet-api', version: '3.1.0'
testCompile group: 'junit', name: 'junit', version: '4.+'
compile group: 'org.postgresql', name: 'postgresql', version: '9.0-801.jdbc4'
runtime('org.postgresql:postgresql')
}

ログ
2017-11-09T14:19:14.376642+00:00 heroku[router]: at=info method=GET path="/hello" host=pacific-bastion-55589.herokuapp.com request_id=443651b0-f86d-4b11-a29f-6811e57f97ec fwd="60.120.49.207" dyno=web.1 connect=0ms service=14ms status=500 bytes=1518 protocol=https
2017-11-09T14:19:14.368425+00:00 app[web.1]: SQL failed.
2017-11-09T14:19:14.368589+00:00 app[web.1]: java.lang.ClassNotFoundException: org.postgresql.Driver
2017-11-09T14:19:14.368811+00:00 app[web.1]:     at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1291)
2017-11-09T14:19:14.368918+00:00 app[web.1]:     at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1119)
2017-11-09T14:19:14.368998+00:00 app[web.1]:     at java.lang.Class.forName0(Native Method)
2017-11-09T14:19:14.369116+00:00 app[web.1]:     at java.lang.Class.forName(Class.java:264)
2017-11-09T14:19:14.369489+00:00 app[web.1]:     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
2017-11-09T14:19:14.369223+00:00 app[web.1]:     at pack.Contoller.doGet(Contoller.java:44)
2017-11-09T14:19:14.369302+00:00 app[web.1]:     at javax.servlet.http.HttpServlet.service(HttpServlet.java:635)
2017-11-09T14:19:14.369410+00:00 app[web.1]:     at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
2017-11-09T14:19:14.369595+00:00 app[web.1]:     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
2017-11-09T14:19:14.369679+00:00 app[web.1]:     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
2017-11-09T14:19:14.369788+00:00 app[web.1]:     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
2017-11-09T14:19:14.369906+00:00 app[web.1]:     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)
2017-11-09T14:19:14.369993+00:00 app[web.1]:     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
2017-11-09T14:19:14.370098+00:00 app[web.1]:     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
2017-11-09T14:19:14.370209+00:00 app[web.1]:     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
2017-11-09T14:19:14.370294+00:00 app[web.1]:     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
2017-11-09T14:19:14.370403+00:00 app[web.1]:     at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:803)
2017-11-09T14:19:14.370540+00:00 app[web.1]:     at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
2017-11-09T14:19:14.370618+00:00 app[web.1]:     at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
2017-11-09T14:19:14.370728+00:00 app[web.1]:     at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1459)
2017-11-09T14:19:14.370805+00:00 app[web.1]:     at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
2017-11-09T14:19:14.370909+00:00 app[web.1]:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
2017-11-09T14:19:14.371007+00:00 app[web.1]:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
2017-11-09T14:19:14.371117+00:00 app[web.1]:     at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
2017-11-09T14:19:14.371234+00:00 app[web.1]:     at java.lang.Thread.run(Thread.java:748)
2017-11-09T14:19:14.373085+00:00 app[web.1]:     at pack.Contoller.doGet(Contoller.java:58)
2017-11-09T14:19:14.373082+00:00 app[web.1]: Nov 09, 2017 2:19:14 PM org.apache.catalina.core.StandardWrapperValve invoke
2017-11-09T14:19:14.373086+00:00 app[web.1]:     at javax.servlet.http.HttpServlet.service(HttpServlet.java:635)
2017-11-09T14:19:14.373083+00:00 app[web.1]: SEVERE: Servlet.service() for servlet [pack.Contoller] in context with path [] threw exception
2017-11-09T14:19:14.373084+00:00 app[web.1]: java.lang.NullPointerException
2017-11-09T14:19:14.373087+00:00 app[web.1]:     at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
2017-11-09T14:19:14.373088+00:00 app[web.1]:     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
2017-11-09T14:19:14.373089+00:00 app[web.1]:     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
2017-11-09T14:19:14.373088+00:00 app[web.1]:     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
2017-11-09T14:19:14.373090+00:00 app[web.1]:     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
2017-11-09T14:19:14.373090+00:00 app[web.1]:     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)
2017-11-09T14:19:14.373091+00:00 app[web.1]:     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
2017-11-09T14:19:14.373092+00:00 app[web.1]:     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
2017-11-09T14:19:14.373092+00:00 app[web.1]:     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
2017-11-09T14:19:14.373094+00:00 app[web.1]:     at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
2017-11-09T14:19:14.373093+00:00 app[web.1]:     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
2017-11-09T14:19:14.373095+00:00 app[web.1]:     at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
2017-11-09T14:19:14.373094+00:00 app[web.1]:     at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:803)
2017-11-09T14:19:14.373097+00:00 app[web.1]:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
2017-11-09T14:19:14.373096+00:00 app[web.1]:     at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1459)
2017-11-09T14:19:14.373096+00:00 app[web.1]:     at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
2017-11-09T14:19:14.373099+00:00 app[web.1]:     at java.lang.Thread.run(Thread.java:748)
2017-11-09T14:19:14.373098+00:00 app[web.1]:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
2017-11-09T14:19:14.373098+00:00 app[web.1]:     at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
2017-11-09T14:19:14.373100+00:00 app[web.1]: 

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

WEB-INF配下にlibフォルダを作成し、その中にjarを追加することで解決しました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/11/10 22:38

    いまさらだけど

    runtime('org.postgresql:postgresql')

    だけを削除すれば解決するきがするよな

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.99%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Java

    12182questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • PostgreSQL

    868questions

    PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

  • Heroku

    633questions

    HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

  • Gradle

    101questions

    Gradleは、ビルド自動化ツールです。 ソフトウェアパッケージやドキュメント、 または実際に何か他の種類のプロジェクトの構築、テスト、公開、展開などを自動化が出来ます

  • トップ
  • Javaに関する質問
  • GradleプロジェクトをHerokuへデプロイし、アクセスしたところ「java.lang.ClassNotFoundException: org.postgresql.Driver」がでてしまう