gpt4 book ai didi

html - 从 multer 返回未定义的答案

转载 作者:太空宇宙 更新时间:2023-11-04 03:30:07 26 4
gpt4 key购买 nike

我在我的nodejs应用程序中使用multer来上传文件。前端部分用 angularjs 。单击上传图像后,在控制台上我得到未定义的答案。任何人都可以帮我解决这个问题吗?这里我把代码贴出来。server.js

var express = require('express');
var app = express();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var bodyParser = require('body-parser');
var path = require('path');
var fs = require('fs');
var spawn = require('child_process').spawn;

var multer = require('multer');
var storage = multer.diskStorage({
destination:function(req,file,cb){
cb(null,'public/upload/');
},
filename:function(req,file,cb){
cb(null,file.originalname);
}
});

var upload = multer({storage: storage});

app.set('views', __dirname + '/views');

app.use(bodyParser.json());
var urlencodedParser = bodyParser.urlencoded({ extended: true });

app.use(express.static('public'));

app.get('/',function(req,res){
res.render('index',{ title: 'Upload image' });
});

app.post('/loadImage',upload.any(),function(req, res) {
console.log(req.files);
console.log("Inside post");
});
http.listen(8080,'0.0.0.0',function(){
console.log('listening on 8080');
})

这是我的 app.js angularjs 代码

var app = angular.module('app',['ui.router','ui.bootstrap','ngAnimate']);
$scope.img={};
app.controller('Ctrl',function ($scope,$http){
$scope.loadImage = function(){
$http.post('/loadImage',$scope.img).success(function(data){
console.log('Posted successfully');
}).error(function(data){
console.error('error');
})
};

还有我的 HTML 代码:

<form ng-submit="loadImage()" enctype="multipart/form-data">
<input type="file" name="file" multiple />
<input type="submit" value="Upload Image" name="submit" />
</form>

在控制台上,我收到未定义和内部帖子。在浏览器控制台上,我发布成功有人可以帮我解决这个问题吗?我应该获取加载的文件信息,而不是未定义

最佳答案

这就是我如何使用 Multer 上传图像

var multer = require('multer');

exports.loadImage = function (req, res) {
var upload = multer({
inMemory: true,
limits: {fileSize: 1024 * 1024 }
}).single('newPicture');

upload(req, res, function (uploadError) {
if (uploadError) {
return res.status(400).send({ message: 'errorUploadingPicture' });
}
else {
var profileImage = 'No data uploaded';
// this is where the photo data is
if (req.file && req.file.buffer) {
profileImage = req.file.buffer;
}
return res.json(profileImage );
}
});

};

关于html - 从 multer 返回未定义的答案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39240825/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com