>  기사  >  웹 프론트엔드  >  Nodejs+express 미들웨어는 파일 업로드를 구현합니다.

Nodejs+express 미들웨어는 파일 업로드를 구현합니다.

青灯夜游
青灯夜游앞으로
2021-04-16 11:00:492276검색

이 글에서는 Nodejs 파일 업로드 방법을 자세히 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

Nodejs+express 미들웨어는 파일 업로드를 구현합니다.

저자는 nodejs로 프로젝트를 할 때 파일 업로드 기능을 사용해야 하는데, 인터넷에서 많은 튜토리얼을 검색하다가 multipart/form-data 유형을 처리하는 Express 미들웨어를 찾았습니다. 양식 데이터는 양식의 파일 데이터를 서버에 쉽게 저장할 수 있습니다. multipart/form-data类型的表单数据,可以很方便的将表单中的文件数据保存到服务器。

介绍


multer是一个node.js文件上传中间件,它是在 busboy的基础上开发的,上传的表单数据必须是multipart/form-data소개

multer는 busboy를 기반으로 개발된 node.js 파일 업로드 미들웨어입니다. 업로드된 양식 데이터는 multipart/form-data 유형이어야 하며, 그렇지 않으면 오류가 발생합니다. 보고됩니다. [관련 추천: "

nodejs 튜토리얼

"] ​

간단한 사용법

저장소 정의

Multer는 Express의 미들웨어로, 업로드된 파일 디렉터리와 저장된 파일 이름을 쉽게 사용자 정의할 수 있습니다. 가장 간단한 사용법을 먼저 살펴보겠습니다.

demo1 address

: file对象,表示当前上传的文件对象,有以下几个属性:

  • fieldname:上传的字段名
  • originalname:上传的文件名
  • encoding:文件的编码类型
  • mimetype:文件的MIME类型

附:一些常用的MIME类型

定义路由回调

var express = require('express');
var multer = require('multer');
var app = express();

var upload = multer({
    storage: multer.diskStorage({
        destination: function (req, file, cb) {
            cb(null, './uploads/');
        },
        filename: function (req, file, cb) {
            //file.originalname上传文件的原始文件名
            var changedName = (new Date().getTime())+'-'+file.originalname;
            cb(null, changedName);
        }
    })
});

在express中定义路由的回调函数时,把定义好了的upload对象作为中间件添加进去。如果是单个文件就用single方法,如果是多个文件就用array方法,这两个方法都需要传一个页面上定义好的字段名。

在路由的回调函数中,request对象已经有了file属性(单个文件上传)或files属性(多个文件上传),files属性是一个数组,数组的每一个对象都有以下属性:

  • fieldname:上传的字段名
  • originalname:上传的文件名
  • encoding:文件的编码类型
  • mimetype:文件的MIME类型
  • destination:存储的目录(和destination回调函数中的目录名一致)
  • filename:保存的文件名(和filename回调函数中的文件名一致)
  • path:保存的相对路径
  • size:文件的大小(单位:字节byte)

  我们可以发现在路由的回调函数中的file对象比diskStorage中的file对象多了几个属性,这是因为在diskStorage中文件还没有保存,只能知道文件的大致属性;而路由的回调函数文件已经在服务器上保存好了,文件的保存路径以及文件的大小都是已知的。

混合上传

有时候我们可能需要用字段名来对上传的文件进行一下划分,比如说上传多个图片的时候可能有身份证还有头像。虽然可以分开放到两个接口中,但是会产生其他一系列的麻烦事。multer支持对图片进行字段名的划分。demo3地址

//单个文件上传
app.post('/upload/single',upload.single('singleFile'),(req,res)=>{
    console.log(req.file);
    res.json({
        code: '0000',
        type:'single',
        originalname: req.file.originalname
    })
});

//多个文件上传
app.post('/upload/multer',upload.array('multerFile'),(req,res)=>{
    console.log(req.files);
    let fileList = [];
    req.files.map((elem)=>{
        fileList.push({
            originalname: elem.originalname
        })
    });
    res.json({
        code: '0000',
        type:'multer',
        fileList:fileList
    });
});

在这边也有req.files

//多字段名上传
let multipleFields = upload.fields([
    {name:'avatar'},
    {name:'gallery', maxCount:3},
]);
app.post('/upload/fields', (req,res)=>{
    multipleFields(req,res,(err) => {
        console.log(req.files);
        if(!!err){
            console.log(err.message);
            res.json({
                code: '2000',
                type: 'field',
                msg:err.message
            })
            return;
        }
        var fileList = [];
        for(let item in req.files){
            var fieldItem = req.files[item];
            fieldItem.map((elem) => {
                fileList.push({
                    fieldname: elem.fieldname,
                    originalname: elem.originalname
                })
            });
        }
        res.json({
            code: '0000',
            type: 'field',
            fileList: fileList,
            msg:''
        })
    });
});

먼저 업로드 객체를 생성합니다. 이 객체의 대상 함수는 업로드된 파일이 저장되는 폴더를 정의하는 데 사용됩니다. 파일을 업로드하여 서버에 저장합니다. 여기에는 간단히 구별하기 위해 타임스탬프를 추가합니다. 두 함수 모두 콜백 함수를 통해 구현됩니다. 이 두 함수는 업로드할 때마다 한 번씩 호출됩니다. 여러 파일이 업로드되면 이 두 함수는 대상을 먼저 호출한 다음 파일 이름을 호출합니다.

두 함수 모두에 file 개체가 있습니다. 이 개체는 현재 업로드된 파일 개체를 나타내며 다음 속성을 갖습니다.
  • fieldname: 업로드된 필드 이름
  • originalname: 업로드된 파일 이름
  • encoding: 파일의 인코딩 유형
  • mimetype: 파일의 MIME 유형

첨부: 일반적으로 사용되는 일부 MIME 유형


라우팅 콜백 정의

{
    "avatar":[{
        fieldname: "",
        originalname: ""
        //...
    }],
    "gallery":[{
        fieldname: "",
        originalname: ""
        //...
    }]
}
라우팅 콜백 기능을 정의할 때 Express에서는 정의된 업로드 객체를 미들웨어로 추가합니다. 단일 파일인 경우 single 방법을 사용하고, 여러 파일인 경우 array 방법을 사용합니다. 두 방법 모두 페이지에 정의된 필드 이름을 전달해야 합니다. 라우트의 콜백 함수에서 요청 개체에는 이미 파일 속성(단일 파일 업로드) 또는 파일 속성(여러 파일 업로드)이 있습니다. 배열의 각 개체에는 다음 속성이 있습니다.

  • fieldname: 업로드된 필드 이름
  • originalname: 업로드된 파일 이름
  • encoding: 파일 인코딩 유형
  • mimetype: 파일 MIME 유형
  • destination: 저장 디렉터리(대상 콜백 함수의 디렉터리 이름과 동일)
  • filename: 저장된 파일 이름(filename 콜백 함수의 파일 이름과 동일)
  • li>
  • path: 저장된 상대 경로
  • size: 파일 크기(단위: 바이트)
라우팅 콜백에서 파일 개체 비율을 확인할 수 있습니다. function diskStorage의 파일 객체에는 여러 가지 속성이 더 있습니다. 이는 파일이 diskStorage에 저장되지 않았고 경로의 콜백 함수 파일이 서버에 저장되어 있는 동안 파일의 일반적인 속성만 알 수 있기 때문입니다. 파일의 저장 경로와 파일 크기는 모두 알려져 있습니다.

🎜🎜혼합 업로드🎜🎜🎜🎜 때로는 업로드된 파일을 구분하기 위해 필드 이름을 사용해야 할 수도 있습니다. 예를 들어 여러 장의 사진을 업로드하는 경우 신분증과 아바타가 있을 수 있습니다. 두 개의 인터페이스로 분리될 수 있지만 일련의 다른 문제가 발생합니다. multer는 이미지를 필드 이름으로 나누는 것을 지원합니다. demo3 주소 🎜🎜
var upload = multer({
    //...其他代码
    fileFilter: function(req, file, cb){
        if(file.mimetype == 'image/png'){
            cb(null, true)
        } else {
            cb(null, false)
        }
    }
});
🎜에도 여기에 req.files 속성이 있지만 이 속성은 배열이 아니라 복잡한 개체입니다. 각 속성 이름은 필드 이름입니다. 배열 아래에는 대략 다음과 같습니다. 🎜🎜파일 업로드 필터링🎜🎜🎜🎜파일을 업로드할 때 가끔 필요하지 않은 파일 형식이 업로드되어 불필요한 파일을 필터링해야 하는 경우가 있습니다. 🎜demo2 주소🎜. 🎜🎜🎜🎜🎜파일 형식 필터링🎜🎜🎜
var upload = multer({
    //...其他代码
    limits:{
        //限制文件大小10kb
        fileSize: 10*1000,
        //限制文件数量
        files: 5
    }
});
🎜 저장소를 정의할 때 필요하지 않은 파일을 필터링하는 fileFilter 함수를 추가합니다. 콜백 함수에서 저장할지 여부를 나타내기 위해 true/false를 전달합니다. ;false가 전달되면 대상 함수와 파일 이름 함수가 호출되지 않습니다. 🎜

文件大小和数量过滤

var upload = multer({
    //...其他代码
    limits:{
        //限制文件大小10kb
        fileSize: 10*1000,
        //限制文件数量
        files: 5
    }
});

在定义存储器的时候,新增一个limits对象,用来控制上传的一些信息,它有以下一些属性:

  • fieldNameSize:field 名字最大长度,默认值:100 bytes
  • fieldSize:field 值的最大长度,默认值:1MB
  • fields:非文件 field 的最大数量
  • fileSize:在multipart表单中, 文件最大长度 (字节单位)
  • files:在multipart表单中, 文件最大数量
  • parts:在multipart表单中, part传输的最大数量(fields + files)

在这边我们把fileSize的值设置得小一点,设为10kb方便测试看效果,但是如果这个时候会发现有报错。因为上传的文件大小很容易就会超过10KB,导致有报错出现,我们就需要在路由回调里对错误的情况进行捕获。

//单个文件上传
let singleUpload = upload.single('singleFile');
app.post('/upload/single',(req,res)=>{
    singleUpload(req,res,(err)=>{
        if(!!err){
            console.log(err.message)
            res.json({
                code: '2000',
                type:'single',
                originalname: '',
                msg: err.message
            })
            return;
        }
        if(!!req.file){
            res.json({
                code: '0000',
                type:'single',
                originalname: req.file.originalname,
                msg: ''
            })
        } else {
            res.json({
                code: '1000',
                type:'single',
                originalname: '',
                msg: ''
            })
        }
    });
});

//多个文件上传
let multerUpload = upload.array('multerFile');
app.post('/upload/multer', (req,res)=>{
    multerUpload(req,res,(err)=>{
        if(!!err){
            res.json({
                code: '2000',
                type:'multer',
                fileList:[],
                msg: err.message
            });
        }
        let fileList = [];
        req.files.map((elem)=>{
            fileList.push({
                originalname: elem.originalname
            })
        });
        res.json({
            code: '0000',
            type:'multer',
            fileList:fileList,
            msg:''
        });
    });
});

所有的demo代码都在仓库里,地址:https://github.com/acexyf/multerDemo

更多编程相关知识,请访问:编程入门!!

위 내용은 Nodejs+express 미들웨어는 파일 업로드를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제