1、安装muterl第三方模块
cnpm install multer --save
2、使用
multer在解析完成后,会向request对象中添加一个body对象和一个file或者files对象(上传多个文件的时候用files对象),其中body中包含提交的字段,而file中包含上传的文件 //1、引入express模块 const express = require("express"); //2、引入multer模块 const multer = require("multer"); //3、对上传的文件进行配置 var storage = multer.diskStorage({ //指定文件上传到服务器的路径 destination: function (req, file, cb) { cb(null, \'/public/img\') }, //指定上传到服务器文件的名称 filename: function (req, file, cb) { cb(null, file.fieldname + \'-\' + Date.now()) } }) var upload = multer({ storage: storage }) //4、使用 在使用路由的时候调用upload方法 name值是客户端传递的key值 var cpUpload = upload.fields([{ name: \'goodsImg\', maxCount: 1 }, { name: \'goodsImgs\', maxCount: 8 }]) router.post(\'/goods/addGoods\',cpUpload,goodsController.addgoods );
3、upload方法
upload.single(\'key值\'):当传递单个文件的时候,对文件的解析 upload.array(\'key值\', maxCout):当传递一组文件的时候,对文件的解析 key值是前端传递的key值 maxcout是最多能传递多少个文件 upload.fields([{ name: \'key值\', maxCount: num }, { name: \'key值\', maxCount: num }]):当传递多个文件域的时候,对文件的解析
4、客户端传递图片
//创建一个表单数据对象 var formData = new FormData(); var goods_name = $("#goods_name"); var goods_des = $("#goods_des"); var goods_price = $("#goods_price"); var goods_img = $("#goods_img"); var goods_imgs = $("#goods_imgs"); formData.append("goodsName",goods_name.val()); formData.append("gooddsDes",goods_des.val()) formData.append("goodsPrice",goods_price.val()) formData.append("goodsImg",goods_img[0].files[0]) for(var i=0;i<goods_imgs[0].files.length;i++){ formData.append("goodsImgs",goods_imgs[0].files[i]) } $.ajax({ type:"post", url:"/api/goods/addGoods", cache: false,//不读取缓存中的结果 true的话会读缓存 其实post本身就不会读取缓存中的结构 processData: false,//默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。 contentType: false,//数据编码格式不使用jquery的方式 为了避免 JQuery 对其操作,从而失去分界符,而使服务器不能正常解析文件。 data:formData, success:$.proxy(this.handleSuccCb) })