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?
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
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. –
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