OPEN HYPER STEP
← 목록으로 (Express)
EXPRESS · 23 / 34
express
CHAPTER 23 / 34
읽기 약 2
FUNCTION

파일 업로드 서비스


핵심 개념

이미지 업로드 서비스를 구축합니다. sharp로 리사이징, multer로 업로드, 업로드된 파일 URL을 반환합니다.

코드 분석
EXPRESS📋 코드 (15줄)
파일 업로드 서비스

const sharp = require('sharp')
const path = require('path')
// 메모리에 받아서 처리
const upload = multer({ storage: multer.memoryStorage() })
app.post('/upload/image', upload.single('image'), async (req, res) => {
  const filename = `${Date.now()}.webp`
  const outPath = path.join('uploads', filename)
  await sharp(req.file.buffer)
    .resize(800, 600, { fit: 'inside' })
    .webp({ quality: 80 })
    .toFile(outPath)
  res.json({ url: `/uploads/${filename}` })
})

AI 프롬프트
🤖 AI에게 잘 물어보는 법 — 모델·전략별 프롬프트
Claude

무료: Sonnet 4.6 / Pro $20/mo: Opus 4.6

이 Express '파일 업로드 서비스' 미들웨어 체인에서
요청 처리 순서 버그·에러 전파 누락·메모리 누수를
찾아서 수정해줘.
ChatGPT

무료: GPT-5.5 / Plus $20/mo: GPT-5.5 Pro

'파일 업로드 서비스'를 사용한 RESTful API를
CRUD 4개 엔드포인트가 포함된 완성 코드로 만들어줘.
Gemini

무료: 2.5 Flash / Pro $19.99/mo: 3.1 Pro

이 Express '파일 업로드 서비스' 라우트 구조와
미들웨어 체인 전체를 분석해서
응답 시간·동시성·로깅 개선안을 정리해줘.
Grok

무료: Grok 4.1 / SuperGrok $30/mo

Express '파일 업로드 서비스' vs Fastify·Hono의 동일 기능 구현을
2026년 기준 성능과 생태계로
솔직히 비교해줘.

⭐ 이것만 기억하세요
파일 업로드 서비스 이 3가지만 확실히 잡으세요
1.파일 업로드 후 경로 관리와 삭제 로직이 없으면 서버에 고아 파일이 쌓여 디스크가 가득 찹니다
2.업로드 시 파일 메타데이터를 DB에 저장하고, 삭제 시 DB 레코드와 실제 파일을 함께 제거합니다
3.다음 챕터에서 WebSocket 기반 실시간 채팅 서버를 구현합니다


공유하기
진행도 23 / 34