4

簡単な Web サーバーを作成しましたが、短時間に何度もページを更新するとクラッシュします。ブラウザに 127.0.0.1:8080 と入力し、F5 でスパムします。この問題を再現するコードは次のとおりです。

void main()
{
  HttpServer server = new HttpServer();
  server.addRequestHandler((req) => true, handleGET);
  server.listen('127.0.0.1', 8080);
}

void handleGET(HttpRequest req, HttpResponse res)
{
  var requestedFile = ".${req.path}";

  if(req.path == "/")
  {
    requestedFile = requestedFile.concat("index.html");
  }

  File file = new File(requestedFile);
  file.exists().then((bool found) {
    if(found)
    {
      file.openInputStream().pipe(res.outputStream);
    }
    else
    {
      res.statusCode = HttpStatus.NOT_FOUND;
      res.outputStream.close();
    }
  });
}

私が得るエラーは次のとおりです。

Unhandled exception:
StreamException: Stream closed
#0      _SocketOutputStream._write (dart:io:6017:30)
#1      _HttpResponse._writeHeader (dart:io:5981:18)
#2      _HttpRequestResponseBase._ensureHeadersSent (dart:io:2696:19)
#3      _HttpResponse._streamClose (dart:io:2921:23)
#4      _HttpOutputStream.close (dart:io:3078:36)
#5      _pipe.<anonymous closure> (dart:io:6271:28)
#6      _BaseDataInputStream._checkScheduleCallbacks.issueCloseCallback (dart:io:6231:59)
#7      _Timer._createTimerHandler._handleTimeout (dart:io:6804:28)
#8      _Timer._createTimerHandler._handleTimeout (dart:io:6812:7)
#9      _Timer._createTimerHandler.<anonymous closure> (dart:io:6820:23)
#10     _ReceivePortImpl._handleMessage (dart:isolate-patch:37:92)

多くの場合、この市長の例外の前に、WSASend failed: 10053 のような一連の警告を受け取りますが、それらはサーバーをクラッシュさせません。この問題が特定の実装に関連している場合、私は Windows で作業しています。

4

1 に答える 1

2

リロードを非常に迅速に実行しているため、コードは既に閉じられているソケットに書き込もうとすることになります。したがって、おそらく StreamException をキャッチして無視する必要があります。io ライブラリがもう少し役立つはずだと主張することができます。このバグを報告しました:

http://code.google.com/p/dart/issues/detail?id=7334&thanks=7334&ts=1355280746

于 2012-12-12T02:52:52.240 に答える