你的 Express 应用还在裸奔?赶紧加上这层错误处理的保护罩!

一、错误处理的核心机制

Express通过四参数中间件构建错误处理流水线,需特别注意:

javascript 复制代码
// 错误中间件标准结构
app.use((err, req, res, next) => {
  console.error(err.stack);
  res.status(500).json({error: err.message || '服务器内部错误'  });
});

执行顺序原则 :必须定义在所有常规中间件和路由之后

错误传递机制 :通过next(err)触发错误处理链

响应灵活性:支持HTML、JSON、纯文本等多种响应格式

开发陷阱 :忘记调用next(err)会导致错误未被捕获,引发进程崩溃

二、同步与异步错误的差异化处理

  1. 同步错误自动捕获

    javascript 复制代码
    app.get('/sync', (req, res) => {
      throw new Error('同步错误示例'); // Express自动捕获
    });
  2. 异步错误必须显式传递

    javascript 复制代码
    // Promise方案
    app.get('/async', async (req, res, next) => {
      Promise.reject(new Error('异步错误示例'))
       .catch(next); // Correctly pass 'next' without calling it immediately,必须手动调用next方法
    });
    
    // Callback方案
    app.get('/callback', (req, res, next) => {
      fs.readFile('missing.txt', (err, data) => {
        if (err) return next(err); // 错误传递关键
        res.send(data);
      });
    });

三、错误处理架构设计(防御体系)

  1. 日志记录层

    javascript 复制代码
    function logErrors(err, req, res, next) {
      console.error(`${Date.now()}|${req.ip}|${err.stack}`);
      next(err); // 传递给下一层
    }
  2. 客户端错误层

    javascript 复制代码
    function clientErrorHandler(err, req, res, next) {
      if (req.xhr) {
        res.status(500).json({code: 'API_ERR'}); // AJAX请求专用响应
      } else {
        next(err);
      }
    }
  3. 终极兜底层

    javascript 复制代码
    app.use((err, req, res, next) => {
      if (res.headersSent) {
        return next(err); // 交还Express默认处理
      }
      res.status(500).send('系统开小差了,工程师正在抢修!');
    });
  4. 未匹配路由处理

    javascript 复制代码
    app.use('*', (req, res) => {
      res.status(404).sendFile('./public/404.html'); // 统一404页面
    });
相关推荐
风中飘爻6 分钟前
JavaScript:BOM编程
开发语言·javascript·ecmascript
还是鼠鼠6 分钟前
Node.js 跨域 CORS 简单请求与预检请求的介绍
运维·服务器·vscode·中间件·node.js·express
我命由我123451 小时前
35.Java线程池(线程池概述、线程池的架构、线程池的种类与创建、线程池的底层原理、线程池的工作流程、线程池的拒绝策略、自定义线程池)
java·服务器·开发语言·jvm·后端·架构·java-ee
whoarethenext4 小时前
qt的基本使用
开发语言·c++·后端·qt
清岚_lxn5 小时前
原生SSE实现AI智能问答+Vue3前端打字机流效果
前端·javascript·人工智能·vue·ai问答
萌萌哒草头将军7 小时前
💎这么做,cursor 生成的代码更懂你!💎
javascript·visual studio code·cursor
lauo8 小时前
智体知识库:ai-docs对分布式智体编程语言Poplang和javascript的语法的比较(知识库问答)
开发语言·前端·javascript·分布式·机器人·开源
草捏子8 小时前
主从延迟导致数据读不到?手把手教你架构级解决方案
后端
拉不动的猪8 小时前
设计模式之------单例模式
前端·javascript·面试
橘猫云计算机设计8 小时前
基于Python电影数据的实时分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·后端·python·信息可视化·小程序·毕业设计