我的图片上传工作在我的项目中,但是我想组织整理一下。
理想情况下,我希望在功能或控制器中完成图像上传。我之前已经在我的路线文件中完成了图像上传。像这样:
route.js:
var upload = multer({
storage: multer.diskStorage({
destination: function(req, file, cb) {
cb(null, 'public/cms/images/uploads')
},
filename: function(req, file, cb) {
cb(null, randomString.generate({length: 7, charset: 'alphanumeric'}) + path.extname(file.originalname))
}
})
})
router.post('/fileupload', login_controller.requires_login, upload.single('imagefile'), test_controller.file_upload_post);
这种作品。这个问题是,我需要对可以上传的内容设置一些限制,并在模板上显示错误消息。如果我将其与我的路线文件分开,这将更加整洁。
为什么这不起作用?
我在名为“upload_image”的控制器中创建一个函数,并在路径中调用它。
route.js:
router.post('/blogpost/create', blog_controller.upload_image, blog_controller.blog_create_post);
blogController.js:
exports.upload_image = function (req, res, next) {
var upload = multer({
storage: multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'public/cms/images/uploads')
},
filename: function (req, file, cb) {
cb(null, randomString.generate({ length: 7, charset: 'alphanumeric' }) + path.extname(file.originalname))
}
})
})
upload.single('imagefile');
return next();
}
当我这样做时, req.body和req.file 是未定义的。没有图片上传。没有错误消息,模板呈现正常,除了我使用req.body或req.file的任何地方。
不会使用表单数据修改req对象吗?这并不意味着我可以在使用next()后将其转发给我的其他控制器。我想要 blog_controller.blog_create_post 然后根据请求执行我需要的所有其他操作。
谢谢,希望你能提供帮助。
答案 0 :(得分:3)
调用upload.single('imagefile')
不会做任何事情。它等同于:
exports.upload_image = function (req, res, next) {
var upload = multer({
storage: multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'public/cms/images/uploads')
},
filename: function (req, file, cb) {
cb(null, randomString.generate({ length: 7, charset: 'alphanumeric' }) + path.extname(file.originalname))
}
})
})
function (req, res, next) {}
return next();
}
记住multer
只是中间件。确切的逻辑multer
显示为here。
因此,如果我正确理解了multer
的来源,那么这样的内容可能会有效:
exports.upload_image = function (req, res, next) {
var upload = multer({
storage: multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'public/cms/images/uploads')
},
filename: function (req, file, cb) {
cb(null, randomString.generate({ length: 7, charset: 'alphanumeric' }) + path.extname(file.originalname))
}
})
})
returnupload.single('imagefile')(req, res, next)
return next();
}
我没有测试过,但有类似的东西。