当前位置:首页 > 技术 > 正文内容

Node.js Multer 文件上传与进度追踪实现

访客 技术 2026年5月23日 4

Multer 文件处理中间件

Multer 是专为 Node.js 设计的文件上传处理中间件,能够有效处理 multipart/form-data 格式的表单数据,特别适用于文件上传场景。该中间件提供了文件接收、保存、大小限制和类型验证等功能。

Multer 基础配置流程

  1. 安装依赖:通过 npm 包管理器安装 multer 模块
npm install multer
  1. 配置存储选项
// 设置文件存储引擎
const fileStorage = multer.diskStorage({
    // 文件存储目录
    destination: function (request, file, callback) {
        callback(null, process.cwd() + '/assets/uploads')
    },
    // 自定义文件名
    filename: function (request, file, callback) {
        // 提取文件名和扩展名
        const originalName = path.parse(file.originalname).name
        const fileExtension = path.parse(file.originalname).ext
        // 生成唯一文件名
        const uniqueName = originalName + Date.now() + '-' + Math.floor(Math.random() * 9000 + 1000) + fileExtension
        callback(null, uniqueName)
    }
})

// 导出 multer 实例
module.exports.fileUpload = multer({
    storage: fileStorage,
    limits: {
        fileSize: 2000000, // 限制文件大小为 2MB
        files: 1           // 限制同时上传的文件数量
    }
})
  1. 路由处理
// 处理图片上传请求
router.post('/upload', function(request, response, next) {
    // single 方法中的参数对应表单中文件输入域的 name 属性
    fileUpload.single('document')(request, response, function(error) {
        if (error instanceof multer.MulterError) {
            next(new Error('文件上传失败,请确保文件大小不超过 2MB'))
        } else {
            response.json({
                code: 0,
                message: '',
                data: '/assets/uploads/' + request.file.filename
            })
        }
    })
})

通过 request.file 可以访问上传文件的详细信息。

前端上传进度实现

HTML 结构
<input type="file" id="fileSelector" />
<progress id="progressIndicator" value="0" max="100"></progress>
JavaScript 实现
// 文件选择事件监听
document.getElementById('fileSelector').addEventListener('change', function(event) {
  const selectedFile = event.target.files[0];
  if (selectedFile) {
    handleFileUpload(selectedFile);
  }
});

// 文件上传处理函数
function handleFileUpload(file) {
  const xhr = new XMLHttpRequest();
  const progressBar = document.getElementById('progressIndicator');
  
  // 监听上传进度
  xhr.upload.addEventListener('progress', function(event) {
    if (event.lengthComputable) {
      const percentage = (event.loaded / event.total) * 100;
      progressBar.value = percentage;
    }
  });
  
  // 上传完成回调
  xhr.addEventListener('load', function() {
    if (xhr.status === 200) {
      showNotification('文件上传成功!', 'success');
    } else {
      showNotification('文件上传失败!', 'error');
    }
  });
  
  // 上传错误处理
  xhr.addEventListener('error', function() {
    showNotification('上传过程中发生错误!', 'error');
  });
  
  // 初始化请求
  xhr.open('POST', '/api/upload', true);
  
  // 创建表单数据对象
  const formData = new FormData();
  formData.append('document', file);
  
  // 发送请求
  xhr.send(formData);
}

// 通知提示函数
function showNotification(message, type) {
  const notification = document.createElement('div');
  notification.className = `notification ${type}`;
  notification.textContent = message;
  document.body.appendChild(notification);
  
  setTimeout(() => {
    notification.remove();
  }, 3000);
}

使用 Fetch API 替代方案

async function uploadFileWithFetch(file) {
  const progressBar = document.getElementById('progressIndicator');
  
  try {
    const response = await fetch('/api/upload', {
      method: 'POST',
      body: file,
      // 使用自定义跟踪上传进度
      onUploadProgress: (progressEvent) => {
        const percent = Math.round((progressEvent.loaded / progressEvent.total) * 100);
        progressBar.value = percent;
      }
    });
    
    if (response.ok) {
      const result = await response.json();
      console.log('上传成功:', result);
    } else {
      throw new Error('上传失败');
    }
  } catch (error) {
    console.error('上传错误:', error);
  }
}
标签: Node.jsMulter

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。