node.js - 数据库查询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: "..."
.. },
]
}
通常如何构造一条错误消息以显示给用户(而不是简单地显示“查询发生错误”)?
注意:我知道使用前端验证可以防止这种情况,但其他事情可能会出错(除了非空验证),所以这只是一个发生错误时的简单示例,不一定是我在实践中会做的.
解决方案
应该为每个 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
这些消息可以由前端解析并显示出来。
推荐阅读
- angular - 可观察到的特殊结果:使用 Jasmine 弹珠进行测试
- wordpress - 在 Wordpress 的 s2Member 中更新 Paypal API 签名时是否有任何“陷阱”?
- python - 如何在python中读取用空格分隔的json对象的文本文件
- java - 简化嵌套 if else 循环 Java 中的认知复杂性
- typescript - 如何使用 TypeScript 泛型函数来强制传入的类型上存在的属性?
- java - 查询参数长度限制
- sqlite - 如何让 sqlite 接受阿拉伯语?
- php - 分页并显示在 laravel 中远程检索的数据
- sql - 我可以使用 string_split 来强制标签组合吗?
- kubernetes - 如何为 Pod 提供节点的 CPU 数量