【nodejs】--express的中间件multer实现图片文件上传--【XUEBIG】

Multer是nodejs中处理multipart/form-data数据格式(主要用在上传功能中)的中间件。该中间件不处理multipart/form-data数据格式以外的任何形式的数据
Tips:multipart/form-data是用来指定传输数据的特殊类型的,主要就是我们上传的非文本的内容,比如图片或者mp3等等
 
1、安装第三方插件
cnpm install multer --save
 
2、配置文件
//引入依赖模块
var express = require('express');
var router = express.Router();
var multer = require("multer");
 
var storage = multer.diskStorage({
 
    //将上传的文件存储在指定的位置(不存在的话需要手动创建)
    destination: function (req, file, cb) {
        cb(null, './public/imgs') }, //将上传的文件做名称的更改 filename: function (req, file, cb) { cb(null, Date.now()+"-"+file.originalname ) } }) //创建multer对象 var upload = multer({ storage: storage }) //指定当前字段可以携带多个文件 var cpUpload = upload.fields([{ name: 'companylogo', maxCount: 1 }]) // 导出模块 module.exports = router;
 
3、解析 upload方法:
      
  upload.single('key值'):当传递单个文件的时候,对文件的解析,该附件将被保存到req.file属性中
 
        upload.array('key值', maxCout):当传递一组文件的时候,对文件的解析 key值是前端传递的key值, maxcout是最多能传递多少个文件,如果附件的数量大于maxCount则抛出异常。文件数组将被储存到req.files属性中。
 
        upload.fields([{ name: 'key值', maxCount: num }, { name: 'key值', maxCount: num }]):当传递多个文件域的时候,对文件的解析,附件将被保存到req.files属性中(是一个对象数组)
 
        .any()接收所有提交的数据,保存到req.files属性中
 
4、file为上传字段名称,当使用form表单submit方式上传时,必须与表单上传的name属性保持一致。表单记得加上 enctype=‘multipart/form-data’
 
客户端传递(使用formdata模拟表单提交数据)
//创建一个表单数据对象
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"); //使用append方法将数据提交到formdata中 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请求 $.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) })

上一篇是关于formdata的详解

猜你喜欢

转载自www.cnblogs.com/xuelanying/p/10547009.html