1

我在Tomcat 8.5.6JDK 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 更改为providedinbuild.gradle并注释了与grails-core#10196groovy-ant相关的依赖项

我在这里看到了一个答案,但这没有用,当我们通过运行时,上面的代码工作正常grails run-app

更新

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

4

1 回答 1

1

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

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

这很烦人,因为 Grails 在这里有效地破坏了现有的合同,并迫使您修改上游代码以允许它在 Grails 上运行。或者转储 Grails,因为它不能很好地与完全有效的 Groovy 代码配合使用。

我相信替换“作为列表”甚至不会解决.asType(List)问题,因为您仍在调用相同的代码。充其量你可以尝试.collect([]) {it}。可能不需要将空数组添加为 collect 的第一个参数。

于 2016-10-27T14:53:25.807 回答