从客户端的mongo _id中提取日期

时间:2012-04-27 06:51:29

标签: javascript node.js mongodb

我将文档_id客户端用作字符串。我希望能够在服务器上从这个值中提取时间戳。是否可以在客户端重新创建此功能? (重写为objectid,或创建一个独立的函数来提取此数据)

示例_id: "4f94c2a11a6bbec3872cb315"

谢谢!

1 个答案:

答案 0 :(得分:9)

这个怎么样,细分为步骤......不幸的是,它只是存储在ObjectID中的第二个解析时间。

var id = "4f94c2a11a6bbec3872cb315"​;
// first 4 bytes are the timestamp portion (8 hex chars)
var timehex = id.sub​string(0,8);
console.log(timehex); // gives: 4f94c2a1

// convert to a number... base 16
var secondsSinceEpoch = parseInt(timehex, 16);
console.log(secondsSinceEpoch); // gives: 1335149217

// convert to milliseconds, and create a new date
var dt = new Date(secondsSinceEpoch*1000);
console.log(dt);​ // gives: Sun Apr 22 2012 22:46:57 GMT-0400 (EDT)

如果要测试,请参阅jsfiddle:http://jsfiddle.net/pZdyM/

注意:这是一种kludgy - 它取决于当前的ObjectID格式。他们可能会在一天内在ObjectID中移动时间戳,这会打破这个。