如何在nodejs控制器中添加中间件?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (86)

我有一个如下所示的router.js:

'use strict';

const express = require('express');
const router = express.Router();

const signupController = require('../controller/signup.controller');
const signinController = require('../controller/signin.controller');
const userListController = require('../controller/userList.controller');
const productController = require('../controller/product.controller');

const passport = require('passport');
require('../config/passport')(passport);


router.get('/users', passport.authenticate('jwt', {session: false}), userListController.getUserList);

router.post('/product', productController.addProduct)

router.post('/user/signup', signupController.Signup);

router.post('/user/signin', signinController.Signin);


module.exports = router;

并在productController.addProduct我有这样的代码:

'use strict';
var mongoose = require('mongoose');
var Product = require('../model/product.model');
var multer = require('multer');
var path = require('path');


// File storage configuration
const storage = multer.diskStorage({
    destination: (req, file, cb) => {
        cb(null, '...store some where in filesystem...');
    }
});

// File filter configuration
const fileFilter = (req, file, cb) => {
    if (path.extname(file) === '.gpg') {
        cb(null, true);
    } else {
        cb(null, false);
    }
};

// File upload configuration
const upload = multer({
    storage: storage,
    limits: {
        fileSize: 1024 * 1024 * 5
    },
    //fileFilter: fileFilter
});


// Loader module
exports.addProduct = (req, res, next) => {
    console.log(req.file);
    ...    
} 

如何将上传添加到exports.addProduct =(req,res,next)=> {},这样我就可以访问req.file

我试过这样的事情,但没有奏效:

exports.addProduct =(upload.single('productImage'),(req,res,next)=> {}

提问于
用户回答回答于

我会试试这个:

productController出口你的upload。所以你需要添加:

exports.upload = upload;

// Loader module
exports.addProduct = ... // like in your code

由于路由器功能期望所有回调,请修改你的router.js

router.post('/product', productController.upload, productController.addProduct);

热门问答

腾讯会议共享屏幕,其他人收到的是黑屏?

AI学习社一个人工智能的死忠粉,让我们一起了解人工智能

你分享给谁 让谁看下腾讯会议应用的权限 是否都开启了

腾讯云音视频 支持 移动端h5吗( 不是小程序的)?

shixin

腾讯 · 高级产品经理 (已认证)

推荐

实时音视频TRTC的Web版是基于WebRTC的方案,需要浏览器的对WebRTC的支持,支持WebRTC的浏览器就可以。但是,移动端浏览器对WebRTC支持的情况并不好,建议使用小程序版。

如何用命令修改腾讯云解析目标ip?

氧化先生道可道 非常道 名可名 非常名
推荐
可以,参考: https://cns.api.qcloud.com/v2/index.php? &<公共请求参数> &Action=RecordCreate &domain=qcloud.com &subDomain=www &recordType=A &recordLine=默...... 展开详请

组队匹配完整流程是怎样的?感觉缺少API支持?

您好,matchgroup匹配成功后,小组成员会进入同一个房间和同一个队伍,这个API需要传玩家ID,通过邀请好友进房间就能拿到玩家的id,解散房间后再调用matchgroup,在没有解散房间不能调用matchGroup 接口。

腾讯云IoT物联平台中如何自定义Topic?

DylanRichard

腾讯 · 产品经理 (已认证)

万物互联的时代,欢迎来到IoT的世界
推荐已采纳
第二个是物联网通信平台(IoT Hub)的,https://cloud.tencent.com/document/product/634/32546。目前物联网开发平台(IoT explorer)只支持基于数据模板协议的接入(文档 https://cloud.tencent.co...... 展开详请

SCF使用了k8s或docker容器技术吗?

Mason-Serverless

腾讯 · 产品经理 (已认证)

推荐

SCF的新架构使用的轻量化虚拟机技术,同时MVM里内嵌的有docker,但是没有使用K8S

所属标签

扫码关注云+社区

领取腾讯云代金券