如何在插入或更新Vertx之前使mongo验证文档?

时间:2019-04-01 13:54:35

标签: javascript mongodb vert.x

我是使用Vertx的新手,我正在使用Javascript使用Vertx + Mongo构建基本的Api Rest。

我正在寻找一种在插入或更新之前自动验证传入文档的方法(例如,类似Mongoose的架构)。

我得到了以下内容:

POST入口点:插入一只新猫

var BodyHandler = require("vertx-web-js/body_handler");
var Router = require("vertx-web-js/router");
var router = Router.router(vertx);
router.post("/cat")
    .produces("application/json")
    .handler(BodyHandler.create().handle)
    .handler(controller.createCat);

控制器功能插入新猫

createCat: function (ctx) {
  var response = ctx.response();
  var body = ctx.getBodyAsJson() || {};

  console.log('inserting cat')

  connection.mongoClient.insert("cats", { name: body.name }, function (res, res_err) {
    if (res_err == null) {
      var id = res;
      console.log("Inserted cat with id " + id);
      response.putHeader("content-type", "application/json");
      response.end(JSON.stringify(id));
    } else {
      console.log('err')
      res_err.printStackTrace();
    }
  });
}

问题是我可以插入空文档,结果文档只有一个字段:mongo ID。

TL; DR-我想知道是否可以通过某种方式告诉Mongo名称字段始终为必填项。

我使用的解决方案:

mongoClient.runCommand("collMod", { collMod: "cats", validator: { $and: [ {"name": {$type: "string", $exists: true}} ] }, validationLevel: "strict", validationAction: "error" }, function(res, res_err) {
  if (res_err) res_err.printStackTrace()
  else console.log('The schema of cats collection has been updated')
});

2 个答案:

答案 0 :(得分:1)

在mongodb中,有一个用于收集查询过滤器的验证概念:https://docs.mongodb.com/manual/core/schema-validation/#query-expressions

如果始终需要“名称”字段,则可以这样创建收藏集:

db.createCollection("cats", {
  validator: {
    $and: [ {"name": {$type: "string", $exists: true}} ]
})

答案 1 :(得分:0)

您可以在单独的json文件中创建自己的架构,然后在您的路由器提供上下文时创建自己的验证方法。

我假设不同的端点具有不同的验证。

您还可以使用gateleen

创建中间件

您有很多选择,使用mongodb可以带来很多好处,但是使用mongodb的重点并不是创建模式。因此,您可以假定该请求应具有特定的必填字段以进行验证。