使用Grails 3.2.0的战争在Tomcat 8上找不到GroovyObject类

时间:2016-10-16 16:22:50

标签: grails tomcat8 grails3 grails3.2.0

我在 Tomcat 8.5.6 JDK 1.8.0_91 上部署了一个 Grails 3.2.0 WAR,其中一个控制器具有以下代码:

package com.test

class MailController {
    static responseFormats = ['json']

    def index() {
        Map headers = (request.headerNames as List).collectEntries {    // It fails on this line
            return [(it): request.getHeader(it)]
        }

        println "Incoming email $headers"
        render status: 200
    }
}

此代码失败,但出现以下异常:

Caused by: java.lang.NoClassDefFoundError: groovy/lang/GroovyObject
    at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:642)
    at groovy.util.ProxyGenerator.instantiateDelegateWithBaseClass(ProxyGenerator.java:225)
    at groovy.util.ProxyGenerator.instantiateDelegateWithBaseClass(ProxyGenerator.java:193)
    at groovy.util.ProxyGenerator.instantiateDelegate(ProxyGenerator.java:185)
    at groovy.util.ProxyGenerator.instantiateDelegate(ProxyGenerator.java:181)
    at org.grails.web.converters.ConverterUtil.invokeOriginalAsTypeMethod(ConverterUtil.java:161)
    at org.grails.web.converters.ConvertersExtension.asType(ConvertersExtension.groovy:56)
    at com.test.MailController.index(MailController.groovy:7)
    at org.grails.core.DefaultGrailsControllerClass$MethodHandleInvoker.invoke(DefaultGrailsControllerClass.java:222)
    at org.grails.core.DefaultGrailsControllerClass.invoke(DefaultGrailsControllerClass.java:187)
    at org.grails.web.mapping.mvc.UrlMappingsInfoHandlerAdapter.handle(UrlMappingsInfoHandlerAdapter.groovy:90)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:963)
    ... 14 common frames omitted
Caused by: java.lang.ClassNotFoundException: groovy.lang.GroovyObject
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    ... 27 common frames omitted

在构建WAR文件之前,我已将嵌入式tomcat更改为provided中的build.gradle,并且还评论了与grails-core#10196相关的groovy-ant依赖项

我看到了答案here,但是当我们通过grails run-app运行时,上述代码工作正常。

更新

我缩短了这个问题。仅在此部分失败request.headerNames as List

1 个答案:

答案 0 :(得分:1)

我很确定问题在于使用"作为List" 。主要是因为Grails将覆盖Groovy的asType实现,这使得"作为X" 强制语法工作。

Grails这样做是为了添加对JSON之类的支持,以便将已知的Grails类型编组为Web传输格式。 不幸的是,Grails还会破坏您自己声明的任何asType函数。或者在这种情况下,Groovy本身已经声明将Enumeration转换为List。

由于Grails在这里有效地破坏现有合同并强迫您修改上游代码以允许它在Grails上运行,因此非常烦人。 那或者转储Grails,因为它没有完美有效的Groovy代码。

我认为用.collect([]) {it}替换"作为列表" 甚至无法解决问题,因为您仍在调用相同的代码。充其量你可以试试sudo apt-get install php-odbc 。可能没有必要将空数组添加为collect的第一个参数。