웹 프론트엔드 JS 튜토리얼 Nodejs 고급: express+multer 기반 파일 업로드 예제

Nodejs 고급: express+multer 기반 파일 업로드 예제

Dec 06, 2016 pm 01:03 PM
nodejs

개요

이미지 업로드는 웹 개발에서 자주 사용되는 기능인데, 노드 커뮤니티 역시 이에 대해 비교적 완벽한 지원을 하고 있습니다.

일반적으로 사용되는 오픈 소스 구성 요소에는 multer, formidable 등이 있습니다. 이 두 오픈 소스 구성 요소의 도움으로 이미지 업로드를 쉽게 수행할 수 있습니다.

이 글에서는 주로 다음 내용을 설명하며, 이후 장에서는 기술 구현 세부 사항에 대해 더 자세히 살펴보겠습니다.

기본 예: express 및 multer를 사용하여 단일 또는 여러 이미지를 업로드합니다.

공통 API: 업로드된 이미지에 대한 정보를 가져옵니다.

고급 사용: 저장된 이미지 경로와 이름을 사용자 정의합니다.

환경 초기화

는 명령 한 줄로 매우 간단합니다.

npm install express multer multer --save
로그인 후 복사

각 예시 아래에는 다음 두 파일이 있습니다.

➜ upload-custom-filename git:(master) ✗ tree -L 1
.
├── app.js # 服务端代码,用来处理文件上传请求
├── form.html # 前端页面,用来上传文件
로그인 후 복사

기본 예: 단일 이미지 업로드

app.js.

var fs = require('fs');
var express = require('express');
var multer = require('multer')
 
var app = express();
var upload = multer({ dest: 'upload/' });
 
// 单图上传
app.post('/upload', upload.single('logo'), function(req, res, next){
  res.send({ret_code: '0'});
});
 
app.get('/form', function(req, res, next){
  var form = fs.readFileSync('./form.html', {encoding: 'utf8'});
  res.send(form);
});
 
app.listen(3000);
로그인 후 복사

form.html.

<form action="/upload-single" method="post" enctype="multipart/form-data">
  <h2>单图上传</h2>
  <input type="file" name="logo">
  <input type="submit" value="提交">
</form>
로그인 후 복사

서비스를 실행합니다.

node app.js

http://127.0.0.1:3000/form을 방문하여 이미지를 선택하고 "제출"을 클릭하면 완료됩니다. 그러면 업로드 디렉터리에 추가 이미지가 표시됩니다.

기본 예: 다중 이미지 업로드

코드는 더 간단할 수 없습니다. 이전 upload.single('logo')를 upload.array('logo', 2)로 변경하면 됩니다. 의미: 동시에 2개의 이미지 업로드를 지원하며 이름 속성은 로고입니다.

app.js.

   
var fs = require(&#39;fs&#39;);
var express = require(&#39;express&#39;);
var multer = require(&#39;multer&#39;)
 
var app = express();
var upload = multer({ dest: &#39;upload/&#39; });
 
// 多图上传
app.post(&#39;/upload&#39;, upload.array(&#39;logo&#39;, 2), function(req, res, next){
  res.send({ret_code: &#39;0&#39;});
});
 
app.get(&#39;/form&#39;, function(req, res, next){
  var form = fs.readFileSync(&#39;./form.html&#39;, {encoding: &#39;utf8&#39;});
  res.send(form);
});
 
app.listen(3000);
로그인 후 복사

form.html.

<form action="/upload-multi" method="post" enctype="multipart/form-data">
  <h2>多图上传</h2>
  <input type="file" name="logos">
  <input type="file" name="logos">
  <input type="submit" value="提交">
</form>
로그인 후 복사

동일한 테스트 단계는 반복되지 않습니다.

업로드된 이미지 정보 가져오기

이미지를 서버에 저장하는 것 외에도 이미지 정보를 데이터베이스에 저장하는 등 많은 작업을 수행해야 하는 경우가 많습니다. .

원본 파일명, 파일 형식, 파일 크기, 로컬 저장 경로 등 자주 사용되는 정보입니다. Multer의 도움으로 우리는 이 정보를 쉽게 얻을 수 있습니다.

이때도 multer는 다음 코드와 같이 req.file에 파일 정보를 작성합니다.

app.js.

var fs = require(&#39;fs&#39;);
var express = require(&#39;express&#39;);
var multer = require(&#39;multer&#39;)
 
var app = express();
var upload = multer({ dest: &#39;upload/&#39; });
 
// 单图上传
app.post(&#39;/upload&#39;, upload.single(&#39;logo&#39;), function(req, res, next){
  var file = req.file;
 
  console.log(&#39;文件类型:%s&#39;, file.mimetype);
  console.log(&#39;原始文件名:%s&#39;, file.originalname);
  console.log(&#39;文件大小:%s&#39;, file.size);
  console.log(&#39;文件保存路径:%s&#39;, file.path);
 
  res.send({ret_code: &#39;0&#39;});
});
 
app.get(&#39;/form&#39;, function(req, res, next){
  var form = fs.readFileSync(&#39;./form.html&#39;, {encoding: &#39;utf8&#39;});
  res.send(form);
});
 
app.listen(3000);
로그인 후 복사

form.html.

<form action="/upload" method="post" enctype="multipart/form-data">
  <h2>单图上传</h2>
  <input type="file" name="logo">
  <input type="submit" value="提交">
</form>
로그인 후 복사
로그인 후 복사

서비스를 시작하고 파일을 업로드하면 콘솔에 정보가 출력되는 것을 볼 수 있습니다.

파일 형식: image/png
원본 파일명: 1.png
파일 크기: 18379
파일 저장 경로: upload/b7e4bb22375695d92689e45b551873d9

맞춤 파일 업로드 경로 및 이름

가끔 파일 업로드 경로와 이름을 사용자 정의하고 싶을 때가 있는데, multer도 이를 쉽게 구현할 수 있습니다.

로컬 저장 경로 사용자 정의

예를 들어 my-upload 디렉터리에 파일을 업로드하려면 대상 구성 항목을 수정하면 됩니다.

var upload = multer({ dest: &#39;upload/&#39; });
로그인 후 복사

위 구성에서는 모든 리소스가 동일한 디렉터리에 저장됩니다. 때로는 다양한 파일에 대한 설정을 개인화해야 하는 경우 다음 섹션을 참조할 수 있습니다.

로컬에 저장된 파일 이름 사용자 지정

코드는 약간 길지만 똑같이 간단합니다. Multer는 리소스 저장 경로와 파일 이름을 개인화하기 위한 저장 매개변수를 제공합니다.

사용 시 주의사항은 다음과 같습니다.

대상: 리소스의 저장 경로를 설정합니다. 이 구성 항목이 없으면 기본적으로 /tmp/uploads에 저장됩니다. 또한 경로를 직접 만들어야 합니다.

filename: 로컬에 저장된 리소스의 파일 이름을 설정합니다.

app.js.

var fs = require(&#39;fs&#39;);
var express = require(&#39;express&#39;);
var multer = require(&#39;multer&#39;)
 
var app = express();
 
var createFolder = function(folder){
  try{
    fs.accessSync(folder);
  }catch(e){
    fs.mkdirSync(folder);
  }
};
 
var uploadFolder = &#39;./upload/&#39;;
 
createFolder(uploadFolder);
 
// 通过 filename 属性定制
var storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, uploadFolder);  // 保存的路径,备注:需要自己创建
  },
  filename: function (req, file, cb) {
    // 将保存文件名设置为 字段名 + 时间戳,比如 logo-1478521468943
    cb(null, file.fieldname + &#39;-&#39; + Date.now());
  }
});
 
// 通过 storage 选项来对 上传行为 进行定制化
var upload = multer({ storage: storage })
 
// 单图上传
app.post(&#39;/upload&#39;, upload.single(&#39;logo&#39;), function(req, res, next){
  var file = req.file;
  res.send({ret_code: &#39;0&#39;});
});
 
app.get(&#39;/form&#39;, function(req, res, next){
  var form = fs.readFileSync(&#39;./form.html&#39;, {encoding: &#39;utf8&#39;});
  res.send(form);
});
 
app.listen(3000);
로그인 후 복사

form.html.

<form action="/upload" method="post" enctype="multipart/form-data">
  <h2>单图上传</h2>
  <input type="file" name="logo">
  <input type="submit" value="提交">
</form>
로그인 후 복사
로그인 후 복사

테스트 단계에 대해서는 자세히 설명하지 않으니 방문하시면 효과를 아실 수 있습니다.

뒤에 적음

이 글에서는 너무 많은 원리를 다루지 않고 multer의 기본적인 사용법을 소개하고 있습니다. 낚시하는 법을 가르치는 것보다 낚시하는 법을 가르치는 것이 낫다는 속담처럼, 다음 장에서는 파일 업로드에 대한 세부 사항을 파헤쳐 독자들이 파일 업로드에 대해 더 깊이 이해할 수 있도록 할 것입니다.


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

nodejs와 vuejs의 차이점 nodejs와 vuejs의 차이점 Apr 21, 2024 am 04:17 AM

Node.js는 서버측 JavaScript 런타임인 반면, Vue.js는 대화형 사용자 인터페이스를 생성하기 위한 클라이언트측 JavaScript 프레임워크입니다. Node.js는 백엔드 서비스 API 개발, 데이터 처리 등 서버 측 개발에 사용되고, Vue.js는 단일 페이지 애플리케이션, 반응형 사용자 인터페이스 등 클라이언트 측 개발에 사용됩니다.

nodejs는 백엔드 프레임워크인가요? nodejs는 백엔드 프레임워크인가요? Apr 21, 2024 am 05:09 AM

Node.js는 고성능, 확장성, 크로스 플랫폼 지원, 풍부한 생태계, 개발 용이성 등의 기능을 제공하므로 백엔드 프레임워크로 사용할 수 있습니다.

nodejs를 mysql 데이터베이스에 연결하는 방법 nodejs를 mysql 데이터베이스에 연결하는 방법 Apr 21, 2024 am 06:13 AM

MySQL 데이터베이스에 연결하려면 다음 단계를 따라야 합니다. mysql2 드라이버를 설치합니다. mysql2.createConnection()을 사용하여 호스트 주소, 포트, 사용자 이름, 비밀번호 및 데이터베이스 이름이 포함된 연결 개체를 만듭니다. 쿼리를 수행하려면 Connection.query()를 사용하세요. 마지막으로 Connection.end()를 사용하여 연결을 종료합니다.

nodejs의 전역 변수는 무엇입니까 nodejs의 전역 변수는 무엇입니까 Apr 21, 2024 am 04:54 AM

Node.js에는 다음과 같은 전역 변수가 존재합니다. 전역 개체: 전역 핵심 모듈: 프로세스, 콘솔, 필수 런타임 환경 변수: __dirname, __filename, __line, __column 상수: undefine, null, NaN, Infinity, -Infinity

nodejs 설치 디렉토리에 있는 npm과 npm.cmd 파일의 차이점은 무엇입니까? nodejs 설치 디렉토리에 있는 npm과 npm.cmd 파일의 차이점은 무엇입니까? Apr 21, 2024 am 05:18 AM

Node.js 설치 디렉터리에는 npm과 npm.cmd라는 두 가지 npm 관련 파일이 있습니다. 차이점은 다음과 같습니다. 확장자가 다릅니다. npm은 실행 파일이고 npm.cmd는 명령 창 바로 가기입니다. Windows 사용자: npm.cmd는 명령 프롬프트에서 사용할 수 있으며, npm은 명령줄에서만 실행할 수 있습니다. 호환성: npm.cmd는 Windows 시스템에만 해당되며 npm은 크로스 플랫폼에서 사용할 수 있습니다. 사용 권장사항: Windows 사용자는 npm.cmd를 사용하고, 기타 운영 체제는 npm을 사용합니다.

nodejs와 java 사이에 큰 차이가 있나요? nodejs와 java 사이에 큰 차이가 있나요? Apr 21, 2024 am 06:12 AM

Node.js와 Java의 주요 차이점은 디자인과 기능입니다. 이벤트 중심 대 스레드 중심: Node.js는 이벤트 중심이고 Java는 스레드 중심입니다. 단일 스레드 대 다중 스레드: Node.js는 단일 스레드 이벤트 루프를 사용하고 Java는 다중 스레드 아키텍처를 사용합니다. 런타임 환경: Node.js는 V8 JavaScript 엔진에서 실행되는 반면 Java는 JVM에서 실행됩니다. 구문: Node.js는 JavaScript 구문을 사용하고 Java는 Java 구문을 사용합니다. 목적: Node.js는 I/O 집약적인 작업에 적합한 반면, Java는 대규모 엔터프라이즈 애플리케이션에 적합합니다.

nodejs는 백엔드 개발 언어인가요? nodejs는 백엔드 개발 언어인가요? Apr 21, 2024 am 05:09 AM

예, Node.js는 백엔드 개발 언어입니다. 서버 측 비즈니스 로직 처리, 데이터베이스 연결 관리, API 제공 등 백엔드 개발에 사용됩니다.

nodejs 프로젝트를 서버에 배포하는 방법 nodejs 프로젝트를 서버에 배포하는 방법 Apr 21, 2024 am 04:40 AM

Node.js 프로젝트의 서버 배포 단계: 배포 환경 준비: 서버 액세스 권한 획득, Node.js 설치, Git 저장소 설정. 애플리케이션 빌드: npm run build를 사용하여 배포 가능한 코드와 종속성을 생성합니다. Git 또는 파일 전송 프로토콜을 통해 서버에 코드를 업로드합니다. 종속성 설치: SSH를 서버에 연결하고 npm install을 사용하여 애플리케이션 종속성을 설치합니다. 애플리케이션 시작: node index.js와 같은 명령을 사용하여 애플리케이션을 시작하거나 pm2와 같은 프로세스 관리자를 사용합니다. 역방향 프록시 구성(선택 사항): Nginx 또는 Apache와 같은 역방향 프록시를 사용하여 트래픽을 애플리케이션으로 라우팅합니다.

See all articles