一尘不染

在JavaScript中缩短MongoDB ID

node.js

如何将mongodb ID缩短到更容易解析语法的URL中。该字符串在当前迭代中太长。

Base64不错,但仍然太长。我正在寻找7个以下字符范围内的更多内容。

我希望能够在node.js和浏览器中对其进行编码/解码。


阅读 303

收藏
2020-07-07

共1个答案

一尘不染

从请求中解析ObjectId并不困难(因此我不确定为什么会出现问题?)。如果目标是创建可键入的URL,那么拥有更短且更“友好”的URL将很有价值。

您不能在分片的MongoDB设置中采用保证唯一的12个字节的数字,并将其压缩为少于12个字节,并且保证它是唯一的(例如,您提到的7个字符以下)。

文档中,MongoDB ObjectId包括:

  • 4字节的时间戳
  • 一个3字节的机器标识符
  • 一个2字节的进程ID
  • 和一个3字节计数器。

因此,您要么需要牺牲ObjectId的一部分(并因此进行分片),要么设计索引的替代ID创建格式。

虽然您可能会散列ID,但再次可能会产生您希望为其编码的冲突(再次,您不能将12个字节缩减为4个字节并保证唯一性)。并且,如果可能发生冲突(并且减少可用位数的总和),那么无论如何您都将需要某种二级表(并且需要创建一个索引来将生成的ID转换为ObjectId)

结果选项:

  • 删除通常有效的位-如果这样做, 请勿 将集合分片
  • 设计自己的独特ID解决方案(如果位于网络农场中,则最终看起来可能与MongoDB非常相似以处理唯一性)
  • 将ObjectId用作长整数并对其运行缩短的算法(由于它超出了JavaScript的53位数字精度,因此需要首先分解为较小的块),例如,尝试使用该算法=对其进行编码(最终会在周围17个字符)
  • 使用其他更短但更独特的名称作为您文档的ID
  • 最简单:只需接受ID长即可。:)

(尚不清楚为什么浏览器需要进行此转换-为什么要具有文档的ObjectID?)

2020-07-07