2014-09-27 8 views
5

Ich versuche Bilder auf den Server via Node.js upoad und downloaden, und ich bin mit dem folgenden Code:Fehler: ENOENT, keine solche Datei oder das Verzeichnis Knoten JS

var http = require('http'), 
    path = require('path'), 
    os = require('os'), 
    fs= require('fs'),url = require('url'); 

var Busboy = require('busboy'); 

http.createServer(function(req, res) { 
    if (req.method === 'POST') { 
    var busboy = new Busboy({ headers: req.headers }); 
    busboy.on('file', function(fieldname, file, filename, encoding, mimetype) { 
     var saveTo = ".\\Images\\"+filename; 
     file.pipe(fs.createWriteStream(saveTo)); 
    }); 
    busboy.on('finish', function() { 
     res.writeHead(200, { 'Connection': 'close' }); 
     res.end("That's all folks!"); 
    }); 
    return req.pipe(busboy); 
    } 
else{ 
    var request = url.parse(req.url, true); 
    console.log(request); 
    var action = request.pathname; 
    console.log(action); 
    if (action !== '/') { 
     var img = fs.readFileSync('.'+action); 
     res.writeHead(200, {'Content-Type': 'image/gif' }); 
     res.end(img, 'binary'); 
    } else { 
     res.writeHead(200, {'Content-Type': 'text/plain' }); 
     res.end('Hello World \n'); 
    } 
    } 
    res.writeHead(404); 
    res.end(); 
}).listen(8082, function() { 
    console.log('Listening for requests'); 
}); 

Wenn ich versuche, das zu bekommen Bild von diesem Server HTTP GET an http://localhost:8082/images/betty.jpg verwendet, wird die Anforderung erfüllt, und das Bild empfangen wird, aber es wirft auch den Fehler unten:

  ^
fs.js:438 
    return binding.open(pathModule._makeLong(path), stringToFlags(flags), mode); 
       ^
Error: ENOENT, no such file or directory 'D:\ImageUploadService\favicon.ico' 
    at Object.fs.openSync (fs.js:438:18) 
    at Object.fs.readFileSync (fs.js:289:15) 
    at Server.<anonymous> (D:\ImageUploadService\service.js:27:20) 
    at Server.emit (events.js:98:17) 
    at HTTPParser.parser.onIncoming (http.js:2112:12) 
    at HTTPParser.parserOnHeadersComplete [as onHeadersComplete] (http.js:121:23 
) 
    at Socket.socket.ondata (http.js:1970:22) 
    at TCP.onread (net.js:527:27) 'D:\ImageUploadService\favicon.ico' 
    at Object.fs.openSync (fs.js:438:18) 
    at Object.fs.readFileSync (fs.js:289:15) 
    at Server.<anonymous> (D:\ImageUploadService\service.js:27:20) 
    at Server.emit (events.js:98:17) 
    at HTTPParser.parser.onIncoming (http.js:2112:12) 
    at HTTPParser.parserOnHeadersComplete [as onHeadersComplete] (http.js:121:23 
) 
    at Socket.socket.ondata (http.js:1970:22) 
    at TCP.onread (net.js:527:27) 

es scheint, dass es für einige favicon.ico sucht. Was könnte das Problem sein?

Antwort

7

Sie müssen prüfen, ob die Datei mit fs.existsSync(path) existiert, bevor es zu lesen:

if (action !== '/' && fs.existsSync('.'+action)) { 
    var img = fs.readFileSync('.'+action); 
    res.writeHead(200, {'Content-Type': 'image/gif' }); 
    res.end(img, 'binary'); 
} else { 
+5

FYI, das ist so etwas wie ein anti-Muster und nicht eine gute Gewohnheit in sein Es ist viel besser, einfach. Fange den Fehler in 'fs.readFileSync()' und handle sicher mit einem ENOENT-Fehler, da dies in einer Multitasking-Welt besser funktioniert. Außerdem sollten Sie keine synchrone Datei-E/A in der Kernereignisbehandlung verwenden. – jfriend00

+1

Sei vorsichtig, 'exists' wird aus Gründen, die von jfriend00 erwähnt werden, ernsthaft veraltet sein und wird nicht in weiteren Versionen von fs funktionieren. –

+0

Webpack und Node-Neuling hier. Verbringen Sie 2 Tage, um das herauszufinden. "exists" kann veraltet sein und dies mag eine schlechte Angewohnheit sein, aber ich muss morgen das Workflow-Setup liefern, und das brauchte ich wirklich. Vielen Dank. – Larrydx

Verwandte Themen