5

我在 tomcat7 上运行 grails 生成的 war 文件时遇到问题。如果/当我使用 grails run-app 运行同一个应用程序时,一切都很好并且工作顺序正确。我在运行 tomcat7 和部署战争时遇到的异常:

2014-08-20 09:17:28,933 [http-bio-127.0.0.1-8080-exec-7] ERROR errors.GrailsExceptionResolver  - ClassNotFoundException occurred when processing request: [GET] /
jline.console.history.History. Stacktrace follows:
java.lang.ClassNotFoundException: jline.console.history.History
    at org.codehaus.plugin.swagger.builder.SwaggerDocsBuilder.buildApiDeclarations(SwaggerDocsBuilder.groovy:71)
    at org.codehaus.plugin.swagger.builder.SwaggerDocsBuilder.rebuild(SwaggerDocsBuilder.groovy:48)
    at org.codehaus.plugin.swagger.builder.SwaggerDocsBuilder.build(SwaggerDocsBuilder.groovy:36)
    at org.codehaus.grails.plugins.swaggerapidocs.SwaggerApiDocsController.resources(SwaggerApiDocsController.groovy:21)
    at grails.plugin.cache.web.filter.PageFragmentCachingFilter.doFilter(PageFragmentCachingFilter.java:198)
    at grails.plugin.cache.web.filter.AbstractFilter.doFilter(AbstractFilter.java:63)
    at com.brandseye.cors.CorsFilter.doFilter(CorsFilter.java:82)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)

第 71 行SwaggerDocsBuilder.groovy

rules = new BuildPathMap().build(grailsApp)

BuildPathMap扩展

import org.codehaus.groovy.grails.web.mapping.reporting.AnsiConsoleUrlMappingsRenderer
class BuildPathMap extends AnsiConsoleUrlMappingsRenderer {

我的猜测在AnsiConsoleUrlMappingsRenderer某种程度上取决于jline.console.history.History但为什么它会从战争文件中丢失?在战争生成期间是否可以做一些事情来确保正确打包 ll 依赖项?

4

3 回答 3

3

它是grails中的一个错误。

https://jira.grails.org/browse/GRAILS-8532

可以通过将以下代码段添加到 BuildConfig.groovy 的解决方法来解决此问题:

grails.war.resources = { stagingDir, args ->
    copy(todir: "${stagingDir}/WEB-INF/lib", flatten: "true") {
        fileset(dir: "${grailsHome}/lib", includes: "**/jline-*.jar, **/jansi-*.jar")
    }
}
于 2015-03-06T00:52:58.963 回答
2

不确定这是否是最佳解决方案,但我能够通过在 BuildConfig.groovy 中显式添加 jLine 依赖项来解决此问题:

runtime 'jline:jline:2.12'

我在 Grails 2.5.1 中没有看到这个错误,但在 Grails 2.5.4 中看到了。似乎是一个错误。

于 2016-04-01T16:12:01.273 回答
0

您的 Tomcat 是否配置为运行未打包或打包的战争。开发作为未打包的战争运行,因此像 servlet.getRealPath() 这样的命令在打包战争上运行时返回一个有效值,Tomcat servlet 容器返回 null。在 server.xml 中搜索 unpackWARs 属性。

  <Host name="localhost"  appBase="webapps"
        unpackWARs="false" autoDeploy="false">

在开发中运行时还会为您添加一些依赖项,您需要在 BuildConfig.groovy 中指定它们,否则它们可能在战争中不可用。

于 2014-08-20T16:20:36.383 回答