RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1565962
Accepted
krokozyablik
krokozyablik
Asked:2024-02-12 16:29:14 +0000 UTC2024-02-12 16:29:14 +0000 UTC 2024-02-12 16:29:14 +0000 UTC

错误处理程序在 Express 中不起作用

  • 772

有一个使用打字稿的打字稿应用程序。我正在尝试处理错误,但我得到的是 html 而不是 json。错误处理程序还应该正确输出 mongo 生成的错误

在此输入图像描述

索引.ts

import express, { Express, NextFunction, Request, Response } from 'express';
import dotenv from 'dotenv';
import connectDB = require('./db/connect-db');
import { apiRouter } from './routes';
import cors from 'cors';
import { errorHandler } from './middleware/error-handler';
import createError from 'http-errors';

dotenv.config();

const app: Express = express();
const port = process.env.PORT || 3000;

try {
  connectDB();
  app.use(cors());
  app.use(express.json());
  app.use((err: any, req: Request, res: Response, next: NextFunction) => {
    console.log('\x1b[31m%s', String('-').repeat(50));
    console.log(err.status);
    console.log(`Message: ${err.message}`);
    console.log(`Path: ${req.path}`);
    console.log('\x1b[31m%s', String('-').repeat(50));

    res
      .status(err?.status || 500)
      .json({ message: err.message, path: req.path, key: err.code, ...err });
  });
  app.use('/api', apiRouter);
} catch (e) {
  console.log(e);
}

app.listen(port, () => {
  console.log(`[server]: Server is running at http://localhost:${port}`);
});

控制器.ts

import User from '../db/models/User';
import { NextFunction, Request, Response } from 'express';
import bcrypt from 'bcrypt';
import createError from 'http-errors';

export const register = async (
  req: Request,
  res: Response,
  next: NextFunction
) => {
  try {
    const { name, email, gender, password, birthday } = req.body;
    const existingUser = await User.findOne({ email });

    if (existingUser)
      createError({ code: 400, message: 'Username already exists' });
    const hashedPass = bcrypt.hashSync(password, 10);
    const user = await User.create({
      name,
      email,
      gender,
      password: hashedPass,
      birthday,
    });
    res.status(200).json(user);
  } catch (error) {
    next(error);
  }
};

export const login = async (
  req: Request,
  res: Response,
  next: NextFunction
) => {
  try {
    const { email, password } = req.body;
    if (!password || !email) {
      throw createHttpError(400, {
        message: 'Please provide both email and password',
        code: 'login - missing email or password',
      });
    }

    const user = await User.findOne({ email });
    if (!user) {
      throw createHttpError(404, {
        message: 'Cannot find user with provided email',
        code: 'login - missing user with provided email',
      });
    }

    const result = bcrypt.compareSync(password, user.password);

    if (!result) {
      throw createHttpError(401, {
        message: 'Invalid email password pair',
        code: 'login - invalid credentials pair',
      });
    }
  } catch (error) {
    next(error);
  }
};

export const list = async (req: Request, res: Response, next: NextFunction) => {
  try {
    const list = await User.find();
    res.status(200).json(list);
  } catch (e) {
    next(e);
  }
};

标题

{
  authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJfaWQiOiI2NWM5ZGU1NDMzZTFkOGFkYmE2NGZmZDYiLCJuYW1lIjoiVGVzdCBVc2VyNyIsImVtYWlsIjoidGVzdDdAZ21haWwuY29tIiwiZGF0ZSI6IjIwMjQtMDItMTJUMDk6MjA6MzguMTUyWiIsImlhdCI6MTcwNzcyOTYzOH0.QbxR12psHSnonExphH-yqUasmdxstlB8hFTBkddrtZc',
  'user-agent': 'PostmanRuntime/7.36.1',
  accept: '*/*',
  'postman-token': '1e119acc-e868-40f2-adb3-f4688f4e55fa',
  host: 'localhost:3000',
  'accept-encoding': 'gzip, deflate, br',
  connection: 'keep-alive'
}
node.js
  • 1 1 个回答
  • 59 Views

1 个回答

  • Voted
  1. Best Answer
    nörbörnën
    2024-02-15T18:28:43Z2024-02-15T18:28:43Z

    您应该最后声明错误处理程序,它应该是定义中的最后一个 - 在其他程序app.use()和路由器之后。

    例子:

    app.use(cors());
    app.use(express.json());
    app.use('/api', apiRouter);
    
    /* Errors handler */
    app.use((err, req, res, next) => {
      // logic
    });
    

    文档:编写错误处理程序

    • 0

相关问题

  • 通过掩码 node.js 指定字符串

  • 从节点 js 发布请求声明变量

  • 为什么 BigQuery 查询如此缓慢?

  • 在 Elasticsearch 中使用 Fluentd 进行映射

  • 如何设置 vuejs 和 nodejs 以使用 mssql

  • 如何添加对象而不覆盖它?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5