我可以确定一个字符串是否是 MongoDB ObjectID 吗?

新手上路,请多包涵

我正在通过将字符串转换为 BSON 来进行 MongoDB 查找。有没有办法让我在进行转换之前确定我拥有的字符串是否是 Mongo 的有效 ObjectID?

这是我当前的 findByID 函数的 coffeescript。它工作得很好,但如果我确定字符串不是 ID,我想通过不同的属性进行查找。

 db.collection "pages", (err, collection) ->
  collection.findOne
    _id: new BSON.ObjectID(id)
  , (err, item) ->
    if item
      res.send item
    else
      res.send 404

原文由 Will 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 758
2 个回答

我发现 mongoose ObjectId 验证器可以验证有效的 objectId,但我发现在一些情况下无效的 id 被认为是有效的。 (例如:任意 12 个字符长的字符串)

 var ObjectId = require('mongoose').Types.ObjectId;
ObjectId.isValid('microsoft123'); //true
ObjectId.isValid('timtomtamted'); //true
ObjectId.isValid('551137c2f9e1fac808a5f572'); //true

对我有用的是将字符串转换为 objectId,然后检查原始字符串是否与 objectId 的字符串值匹配。

 new ObjectId('timtamtomted'); //616273656e6365576f726b73
new ObjectId('537eed02ed345b2e039652d2') //537eed02ed345b2e039652d2

这是有效的,因为有效的 id 在转换为 ObjectId 时不会改变,但是当转换为 objectId 时,获得错误有效的字符串将改变。

原文由 Andy Macleod 发布,翻译遵循 CC BY-SA 3.0 许可协议

您可以使用正则表达式来测试:

咖啡脚本

if id.match /^[0-9a-fA-F]{24}$/
    # it's an ObjectID
else
    # nope

JavaScript

 if (id.match(/^[0-9a-fA-F]{24}$/)) {
    // it's an ObjectID
} else {
    // nope
}

原文由 JohnnyHK 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题