在程序里经常都需要生成一些特定格式的 id ,每种场合的需求都可能有些不一样,虽然写起来代码不复杂,但零零碎碎的东西做多了也挺烦的,于是设计了这个用于 node.js 的万能 ID 生成器。
AnyID 生成的 ID 为字符串(也可以纯数字),信息密度尽可能的高,也就是用最少的位数表示尽量多的信息。
AnyID 设计的首要考虑原则是 API 的直观易用。看看这些例子:
21 个字符,包含大写小写字母和数字。 这个 ID 的碰撞可能性跟 type 4 (random) UUID 一样低。
const ids = anyid().encode('Aa0').length(21).random() const id = ids.id(); 1LrKcmd0uk1Ma8szUxtda
第一段根据进程号生成,第二段根据时间生成。
const ids = anyid() .encode('0A-IO') .section( anyid().fixed(process.pid) ) .delimiter('-') .section( anyid().time() );
生成的 ID 是阅读友好的:排除了字母 I 和 O 因为容易和数字 1和 0混淆。
I
O
1
0
008CL-00TYMZS0P3
这是生成 Twitter Snowflake 风格的 ID ,包含了时间, 序列号和 worker 标识。
const ids = anyid() .encode('0') .bit(41).time().since(new Date('2016-7-1')) .bit(12).seq().resetByTime(); .bit(10).fix(workerId);
为了节省位空间,微秒时间从 2016-7-1 算起。
071243223959339218
每次生成 ID 时调用函数获得返回值。第一段是秒,第二段是纳秒。
const nanotime = () => { return process.hrtime()[1]; }; const ids = anyid() .encode('Aa0') .section( anyid().time('s') ) .delimiter('+') .section( anyid().of(nanotime) ); BlX6bX+j3Uz0
第一二段的值在调用时通过传入参数给出
const ids = anyid() .encode('Aa0') .section( anyid().variable('countryId') ) .delimiter('-') .section( anyid().variable('userId') ) .delimiter('-') .section( anyid().length(5).random() ); const id = ids.id({ countryId: 86, userId: 635023 }); AAABY-ACpMT-EBwQJ