如何配置 Jetty 以允许与 Spark Framework 一起使用时更大的窗体



如何通过Spark框架配置Jetty选项?

当我提交大表格时,我遇到了下面的问题。Jetty 的解决方案记录在表单太大异常中

但是Jetty使用Spark Framework对我隐藏了,我将如何配置以解决此问题。

    org.eclipse.jetty.http.BadMessageException: 400: Unable to parse form content
        at org.eclipse.jetty.server.Request.getParameters(Request.java:373)
        at org.eclipse.jetty.server.Request.getParameter(Request.java:1016)
        at javax.servlet.ServletRequestWrapper.getParameter(ServletRequestWrapper.java:194)
        at spark.Request.queryParams(Request.java:283)
        at spark.http.matching.RequestWrapper.queryParams(RequestWrapper.java:141)
        at com.jthink.songkong.server.callback.ServerEditSongs.startTask(ServerEditSongs.java:45)
        at com.jthink.songkong.server.CmdRemote.lambda$null$62(CmdRemote.java:171)
        at spark.RouteImpl$1.handle(RouteImpl.java:72)
        at spark.http.matching.Routes.execute(Routes.java:61)
        at spark.http.matching.MatcherFilter.doFilter(MatcherFilter.java:130)
        at spark.embeddedserver.jetty.JettyHandler.doHandle(JettyHandler.java:50)
        at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:1568)
        at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
        at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:132)
        at org.eclipse.jetty.server.Server.handle(Server.java:564)
        at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:317)
        at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:251)
        at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:279)
        at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:110)
        at org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:124)
        at org.eclipse.jetty.util.thread.Invocable.invokePreferred(Invocable.java:128)
        at org.eclipse.jetty.util.thread.Invocable$InvocableExecutor.invoke(Invocable.java:222)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKill.java:294)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.java:199)
        at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:673)
        at org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:59
1)
        at java.lang.Thread.run(Thread.java:745)
    Caused by: java.lang.IllegalStateException: Form too large: 273433 > 200000
        at org.eclipse.jetty.server.Request.extractFormParameters(Request.java:516)
        at org.eclipse.jetty.server.Request.extractContentParameters(Request.java:454)
        at org.eclipse.jetty.server.Request.getParameters(Request.java:369)
        ... 26 more

一点历史:

  • 我在 spark 的 git 存储库上查找了一下,发现这个问题是在 2015 年 8 月 3 日提出的,这里是第 314 期

  • Perwendel(维护Spark的人(于2016年10月11日添加了Much wanted标签

  • 然后在2016年11月3日开始工作

  • 他合并了拉取请求PR #813,为Spark嵌入的任何Jetty设置提供了可能性。

我研究了此 PR 中添加的修改,我认为您可以通过实现 JettyServerFactory 来配置一些东西,如果您覆盖 public Server create(...) 方法,您可以返回您的自定义服务器:

public class Main {
  public static void main(String ...args) {
    CustomJettyServerFactory customJettyServerFactory = new CustomJettyServerFactory();
    EmbeddedServers.add(
        EmbeddedServers.Identifiers.JETTY, 
        new EmbeddedJettyFactory(customJettyServerFactory));
  }
}
class CustomJettyServerFactory implements JettyServerFactory {
  @Override
  public Server create(int maxThreads, int minThreads, int threadTimeoutMillis) {
    Server server = new Server();
    server.setAttribute("org.eclipse.jetty.server.Request.maxFormContentSize", 1000000);
    return server;
  }
  @Override
  public Server create(ThreadPool threadPool) {
    return null;
  }
}

请尝试一下,看看您是否可以完成这项工作,我没有任何设置可以尝试,但我认为这是配置 Jetty 服务器的正确路径。

这是

通过org.eclipse.jetty.server.Server属性控制的。

org.eclipse.jetty.server.Request.maxFormContentSize=<int>最大表单大小(以字节为单位(

org.eclipse.jetty.server.Request.maxFormKeys=<int>最大表单键(此处存在限制以对抗哈希键冲突 DoS 技术(。

使用Server.setAttribute(String name, Object value)调用。

相关内容

最新更新