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

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

这是我当前的findByID函数的脚本。效果很好,但是如果我确定字符串不是ID,我想按其他属性查找。

db.collection "pages", (err, collection) ->

collection.findOne

_id: new BSON.ObjectID(id)

, (err, item) ->

if item

res.send item

else

res.send 404

回答:

我发现猫鼬的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时会更改。

以上是 我可以确定字符串是否为MongoDB ObjectID吗? 的全部内容, 来源链接: utcz.com/qa/423560.html

回到顶部