I have set up a simple node.js server with the following code:
var http = require("http");
var url = require('url');
var fs = require('fs');
var server = http.createServer(function(request, response){
console.log('Connection');
var path = url.parse(request.url).pathname;
switch(path) {
case '/':
response.writeHead(200, {'Content-Type': 'text/html'});
response.write('hello world');
break;
case '/socket.html':
fs.readFile(__dirname + path, function(error, data){
console.log(path);
console.log(error);
if (error){
response.writeHead(404);
response.write("opps this doesn't exist - 404");
}
else{
response.writeHead(200, {"Content-Type": "text/html"});
response.write(data, "utf8");
}
});
break;
default:
response.writeHead(404);
response.write("opps this doesn't exist - 404");
break;
}
response.end();
});
server.listen(8001);
Connecting to localhost:8001 works as expected.
However, when I attempt to connect to localhost:8001/socket.html, the server crashes and the following error is displayed to terminal:
events.js:141 throw er; // Unhandled 'error' event ^
Error: write after end at ServerResponse.OutgoingMessage.write (_http_outgoing.js:428:15) at /Users/Nikos/Desktop/hack_reactor/server.js:24:34 at FSReqWrap.readFileAfterClose [as oncomplete] (fs.js:380:3)
While debugging, console.log(error) returns null. Please explain why this is occurring.