Sparkjava 错误:org.eclipse.jetty.http.HttpParser - 标头太大 >8192



我们正在开发一个基于sparkjava框架的内部Web组件,为了方便起见,使用了HTTP GET而不是POST。

当请求 URL 包含大型数据(超过 8K(时,返回错误如下:org.eclipse.jetty.http.HttpParser - Header is too large >8192.

如何解决?

Sparkjava 运行在嵌入式 Jetty 服务器上,但大多数 Jetty 配置默认在 sparkjava 框架中是硬编码的。

一种解决方案是自定义EmbeddedServerFactory:

static Server server = null;
private static void startup() {
EmbeddedServers.add(EmbeddedServers.Identifiers.JETTY, createEmbeddedServerFactory());
awaitInitialization();
Stream.of(server.getConnectors()).map(Connector::getConnectionFactories).flatMap(Collection::stream)
.filter(t -> t.getClass().isAssignableFrom(HttpConnectionFactory.class))
.map(t -> ((HttpConnectionFactory) t).getHttpConfiguration()).forEach(t -> {
t.setRequestHeaderSize(512 * 1024 * 1024);
t.setSendServerVersion(false);
t.setSendDateHeader(false);
});
}
private static EmbeddedServerFactory createEmbeddedServerFactory() {
return new EmbeddedJettyFactory(new JettyServerFactory() {
@Override
public Server create(int maxThreads, int minThreads, int threadTimeoutMillis) {
return create(maxThreads <= 0 ? null
: new QueuedThreadPool(maxThreads, minThreads, threadTimeoutMillis));
}
@Override
public Server create(ThreadPool threadPool) {
return server = new Server(threadPool);
}
});
}

最新更新