0

リクエストが失敗したときにクライアントにエラーを送り返そうとしているだけです。私のコードは次のようになります。

response.sendError(HttpServletResponse.SC_BAD_REQUEST, 
        "Email and username are required fields.");

このコードは、次のエラーをスローします。

java.lang.IllegalStateException: null
    at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:407) ~[catalina-6.0.26.jar:6.0.26]
    at com.****.****.****.*********Servlet.service(********Servlet.java:68) ~[********Servlet.class:na]
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) ~[javaee-api-5.1.2.jar:5.1.2]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) ~[catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) ~[catalina-6.0.26.jar:6.0.26]
    at org.red5.logging.LoggerContextFilter.doFilter(LoggerContextFilter.java:78) ~[red5.jar:na]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) ~[catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) ~[catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) ~[catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:465) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:555) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) [catalina-6.0.26.jar:6.0.26]
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298) [catalina-6.0.26.jar:6.0.26]
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852) [tomcat-coyote-6.0.26.jar:6.0.26]
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588) [tomcat-coyote-6.0.26.jar:6.0.26]
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) [tomcat-coyote-6.0.26.jar:6.0.26]

なぜこれがここに投げられているのですか?この呼び出しの前に、応答オブジェクトに関係することは何もしていません。このエラーがif句で送信されるまで、応答オブジェクトに触れていません。このエラーが発生するのはなぜですか?

4

2 に答える 2

2

HttpServletResponse (ResponseFacade によって実装) が IllegalStateException をスローする唯一の理由は、応答が既にコミットされていることです。すでに誰かに触れられているはずです。

于 2012-06-26T20:52:27.007 に答える
0

ResponseFacade がオーバーライドされない場合、response.sendError() またはエラー ページへの転送につながる場合は、エラー ページに転送する前に応答がコミットされているために発生しています。

この問題を解決するには、

  • 応答をフラッシュしていないことを確認してください
  • 最大バッファー サイズに達したために応答が自動的にコミットされる場合は、バッファー サイズを増やしてみてください。
于 2012-06-27T05:12:32.670 に答える