[英]Error caused by java.lang.NoClassDefFoundError and ClassNotFoundException
[英]deploying java web app to heroku: NoClassDefFoundError caused by ClassNotFoundException
我遵循了这个指令:
https://devcenter.heroku.com/articles/deploying-java
将 Java Web 应用程序部署到 heroku。
我的 Procfile 的内容如下:
web: java $JAVA_OPTS -cp target/classes:target/dependency/* com.michael.optimizer.Optimizer
(Optimizer 是我的主类的名称。)
执行命令
mvn clean install
成功构建项目。
但是然后执行命令
heroku local web
导致以下错误消息:
Exception in thread "main"
5:33:48 PM web.1 | java.lang.NoClassDefFoundError: javax/json/Json
5:33:48 PM web.1 | at com.michael.optimizer.api.JsonRequest.doJsonRequest(JsonRequest.java:29)
5:33:48 PM web.1 | at com.michael.optimizer.api.StationApi.doJsonRequest(StationApi.java:150)
5:33:48 PM web.1 | at com.michael.optimizer.api.StationApi.areaSearch(StationApi.java:73)
5:33:48 PM web.1 | at com.michael.optimizer.Optimizer.main(Optimizer.java:23)
5:33:48 PM web.1 | Caused by: java.lang.ClassNotFoundException: javax.json.Json
5:33:48 PM web.1 | at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
5:33:48 PM web.1 | at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
5:33:48 PM web.1 | at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
5:33:48 PM web.1 | at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
5:33:48 PM web.1 | ... 4 more
我不明白的是:当我在本地运行应用程序时,一切正常。 (它运行良好也就不足为奇了,因为在文件夹 ~/.m2/repository/javax/javaee-web-api/7.0/javaee-web-api-7.0.jar 中应该有 json 包。)
仅当我尝试部署到 heroku 时,显然找不到类 javax.json.Json。
怎么了???
您可能想要使用copy-dependencies ,
mvn install dependency:copy-dependencies
这将复制target/dependencies 中的所有依赖项。
如果要排除测试范围依赖项,
mvn install dependency:copy-dependencies -DexcludeScope=test
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.