首页 > 解决方案 > 数据库查询API报错构建

问题描述

我正在开发一个简单的 API,该 API 使用从表单客户端提供的信息执行对 SQL 数据库的 INSERT 查询,这些信息将在前端填写。我很好奇在构建有关查询错误的错误消息时是否有首选方法。

举一个具体的例子,我有一个由具有属性 A、B 和 C 的用户填写的表单。在 SQL 数据库中,它们都被强制执行“NOT NULL”约束。因此,如果提交了一个空表单,则会返回以下错误对象:

{
...
errors:
  [ ValidateErrorItem {
      message: "model.a cannot be null"
      type: "..."
      path: "..." 
      value: "..."
      .. },
    ValidateErrorItem {
      message: "model.b cannot be null"
      type: "..."
      path: "..." 
      value: "..."
      .. },
    ValidateErrorItem {
      message: "model.c cannot be null"
      type: "..."
      path: "..." 
      value: "..."
      .. },
  ]
}

通常如何构造一条错误消息以显示给用户(而不是简单地显示“查询发生错误”)?

注意:我知道使用前端验证可以防止这种情况,但其他事情可能会出错(除了非空验证),所以这只是一个发生错误时的简单示例,不一定是我在实践中会做的.

标签: node.jspostgresqlapierror-handlingsequelize.js

解决方案


应该为每个 api 请求执行这些类型的验证。我更喜欢使用Joi

每当架构与您的期望不匹配时,Joi 都会抛出错误。例如

const schema = Joi.object().keys({
  modelA: Joi.string().required(),
  modelB: Joi.string().required(),
  modelC: Joi.string().required(),
});

const myObj = { modelA: 'modelA' };
console.log(Joi.validate(myObj, schema));

上面的代码会抛出错误{ ValidationError: child "modelB" fails because ["modelB" is required]

您还可以像这样添加客户错误消息

const schema = Joi.object().keys({
  modelA: Joi.string().required(),
  modelB: Joi.string().required().error(new Error('Was expecting a string')),
  modelC: Joi.string().required(),
});
const myObj = { modelA: 'modelA' };
console.log(Joi.validate(myObj, schema));

这将引发错误

   Error: Was expecting a string

这些消息可以由前端解析并显示出来。


推荐阅读