Настройка Undertow RequestEncodingHandler в Spring Boot - PullRequest
0 голосов
/ 04 апреля 2019

Я пытаюсь включить декомпрессию запроса (gzip) в Undertow.В документации указано, что это обрабатывается RequestEncodingHandler.В конфигурации Spring я создал следующий компонент

@Component
class UndertowWebServerCustomizer : WebServerFactoryCustomizer<UndertowServletWebServerFactory> {
    override fun customize(factory: UndertowServletWebServerFactory) {
        factory.addDeploymentInfoCustomizers(
            UndertowDeploymentInfoCustomizer { deploymentInfo ->
                deploymentInfo.addInitialHandlerChainWrapper { handler ->
                    RequestEncodingHandler(handler)
                        .addEncoding("gzip", GzipStreamSourceConduit.WRAPPER)
                        .addEncoding("deflate", InflatingStreamSourceConduit.WRAPPER)
                }
            }
        )
    }
}

Похоже, Spring выполняет этот код, но когда я пытаюсь загрузить gzip-файл с заголовком Content-Encoding: gzip, я получаю следующую ошибку:

14:51:03.378 [XNIO-2 task-1] ERROR io.undertow.request.io - UT005090: Unexpected failure
java.lang.IllegalStateException: UT000091: Buffer has already been freed
    at io.undertow.server.DefaultByteBufferPool$DefaultPooledBuffer.getBuffer(DefaultByteBufferPool.java:260)
    at io.undertow.conduits.InflatingStreamSourceConduit.read(InflatingStreamSourceConduit.java:93)
    at org.xnio.conduits.ConduitStreamSourceChannel.read(ConduitStreamSourceChannel.java:127)
    at io.undertow.channels.DetachableStreamSourceChannel.read(DetachableStreamSourceChannel.java:209)
    at io.undertow.server.HttpServerExchange$ReadDispatchChannel.read(HttpServerExchange.java:2341)
    at org.xnio.channels.Channels.readBlocking(Channels.java:294)
    at io.undertow.servlet.spec.ServletInputStreamImpl.readIntoBuffer(ServletInputStreamImpl.java:192)
    at io.undertow.servlet.spec.ServletInputStreamImpl.close(ServletInputStreamImpl.java:257)
    at io.undertow.servlet.spec.HttpServletRequestImpl.closeAndDrainRequest(HttpServletRequestImpl.java:682)
    at io.undertow.servlet.core.ServletBlockingHttpExchange.close(ServletBlockingHttpExchange.java:89)
    at io.undertow.server.HttpServerExchange.endExchange(HttpServerExchange.java:1624)
    at io.undertow.server.Connectors.executeRootHandler(Connectors.java:385)
    at io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:830)
    at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
    at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
    at java.base/java.lang.Thread.run(Thread.java:834)

Как правильно настроить эту настройку?

1 Ответ

0 голосов
/ 10 апреля 2019

Судя по всему отправленный код правильный, проблема была в файле gzipped, который я тестировал с

...