ho usato seguente codice:come caricare file immagine e display utilizzando nodejs espressi
fileupload.html
<html>
<head>
<title>File Uploading Form</title>
</head>
<body>
<h3>File Upload:</h3>
Select a file to upload: <br />
<form action="http://127.0.0.1:8081/file_upload" method="POST" enctype="multipart/form-data">
<input type="file" name="file" size="50" />
<br />
<input type="submit" value="Upload File" />
</form>
</body>
</html>
fileupload.js:
var express = require('express');
var app = express();
var fs = require("fs");
var bodyParser = require('body-parser');
var multer = require('multer');
//console.log(multer);
app.use(express.static('public'));
app.use(bodyParser.urlencoded({ extended: false }));
app.use(multer({ dest: '/tmp/'}));
app.get('/fileupload.html', function (req, res) {
res.sendFile(__dirname + "/" + "fileupload.html");
})
app.post('/file_upload', function (req, res) {
console.log(req.files.file.name);
console.log(req.files.file.path);
console.log(req.files.file.type);
var file = __dirname + "/" + req.files.file.name;
fs.readFile(req.files.file.path, function (err, data) {
fs.writeFile(file, data, function (err) {
if(err){
console.log(err);
}else{
response = {
message:'File uploaded successfully',
filename:req.files.file.name
};
}
console.log(response);
res.end(JSON.stringify(response));
});
});
})
var server = app.listen(8081, function() {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
Ho usato questi codice qui sopra per il caricamento di file, ma quando escuto utilizzando il nodo fileupload.js nel terminale sto ricevendo errore di tipo TypeError('app.use() requires middleware functions');
Qualcuno può aiutare a risolvere questo problema.
Grazie mille mscdex .FILE caricato con successo – Khushboo
req.file è indefinito? Come posso risolvere questo ? –
@SunilGarg Assicurati di inviare l'immagine in un campo chiamato "file" quando pubblichi sul tuo server ... – duhaime