Ошибка [ERR_STREAM_WRITE_AFTER_END]: запись после завершения - PullRequest
1 голос
/ 17 марта 2020

Объяснение кода: Я возвращаю файл спецификаций c HTML, когда пользователь указывает специфику c url:

const http = require('http');
const fs = require('fs');

fs.readFile('./funkcionalnosti-streznika.html', function(err1, html1) {
    fs.readFile('./posebnosti.html', function(err2, html2) {
        if (err1 || err2) {
            throw new Error();
        }

        http.createServer(function(req, res) {
            if (req.url == '/funkcionalnosti-streznika') {
                res.write(html1);
                res.end();
            }
            if (req.url == '/posebnosti') {
                res.write(html2)
                res.end();
            } else {
                res.write('random');
                res.end();
            }
        }).listen(8080)
    })
});

на терминале. Я получаю эту ошибку при посещении localhost: 8080 / Функциональность-Стрезника:

events.js:288
      throw er; // Unhandled 'error' event
      ^

Error [ERR_STREAM_WRITE_AFTER_END]: write after end
    at write_ (_http_outgoing.js:637:17)
    at ServerResponse.write (_http_outgoing.js:629:15)
    at Server.<anonymous> (/*filelocation*/:19:21)
    at Server.emit (events.js:311:20)
    at parserOnIncoming (_http_server.js:784:12)
    at HTTPParser.parserOnHeadersComplete (_http_common.js:119:17)
Emitted 'error' event on ServerResponse instance at:
    at writeAfterEndNT (_http_outgoing.js:692:7)
    at processTicksAndRejections (internal/process/task_queues.js:85:21) {
  code: 'ERR_STREAM_WRITE_AFTER_END'

Я думаю, что есть проблема, когда я закрываю ответ слишком рано. Как я должен изменить это, чтобы быть asyn c?.

1 Ответ

3 голосов
/ 17 марта 2020

Вы уже поняли, в чем проблема. Давайте посмотрим на этот код:

    http.createServer(function(req, res) {
        if (req.url == '/funkcionalnosti-streznika') {
            res.write(html1);
            res.end();
        }
        if (req.url == '/posebnosti') {
            res.write(html2)
            res.end();
        } else {
            res.write('random');
            res.end();
        }
    }).listen(8080)

Предположим, что req.url равно '/funkcionalnosti-streznika'. Что просходит? Он входит в первый if, пишет html1 и заканчивается res. Затем он проверяется на '/posebnosti', но он отличается, потому что первый if был верным. Это означает, что ветвь else будет выполнена, поэтому вызывается res.write('random');, но res уже был закрыт в первом if. Предложение:

http.createServer(function(req, res) {
    if (req.url == '/funkcionalnosti-streznika') {
        res.write(html1);
        res.end();
    }
    else if (req.url == '/posebnosti') {
        res.write(html2)
        res.end();
    } else {
        res.write('random');
        res.end();
    }
}).listen(8080)
...