【发布时间】:2020-04-23 14:01:41
【问题描述】:
我遵循了这个指示:
https://devcenter.heroku.com/articles/deploying-java
将 java web 应用程序部署到 heroku。
我的 Procfile 的内容如下:
web: java $JAVA_OPTS -cp target/classes:target/dependency/* com.michael.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。
怎么了???
【问题讨论】:
-
您能否验证在本地运行
mvn clean install后,javaee-web-api-7.0.jar是否存在于您的target/dependency目录中? -
@Malax:非常感谢您的回答,对于迟到的回复感到抱歉。我签入了文件夹目标...运行“mvn clean install”后javaee-web-api-7.0.jar不在该文件夹中...我该如何更改?
-
您能否显示您定义 JEE API 的
<dependency>部分?
标签: java heroku classnotfoundexception noclassdeffounderror javax.json