我们正在开发一个基于 sparkjava 框架的内部 Web 组件,为了方便,使用 HTTP GET 而不是 POST。
请求 URL 包含大数据(超过 8K)时返回错误,如下所示:
org.eclipse.jetty.http.HttpParser - Header is too large >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);
}
});
}