优雅简洁地实现短ID

作者: zzzhan | 来源:发表于2016-05-30 23:43 被阅读1567次
优雅简洁

短ID在实际运用中很广泛, 其中比较典型的运用就是短地址。 市面上肯定有不少开源的生成短ID库, 基于node.js的估计也不少。 鉴于本人已然是node。js的脑残粉(本职java开发), 很多业余项目从前端到后端都基于javascript开发, 加上npm和bower的包管理以及grunt的打包工具, 在项目开发过程中体验特别酸爽。 由于当时项目前后端都会用到短ID, 但没找到合适的库同时支持npm和bower的(可能孤陋寡闻). 因此自己乐此不疲地又造了个轮子js-shortid(夷,为什么会说呢?!). 下面主要介绍它的实现方案, 自认为比较优雅简洁。

js-shortid

js-shortid是一个基本于node.js的开源短ID的产生器, 其生成的短ID满足无序、不可预测、URL地址友好以及足够短且据有唯一的基本特征。下面就是由它产生的实例,先感受一下:

R6zw8Hly
R6AhD4Jw
R6Cip4M3
R6Ej09A1
R6Fjw3Q4
R6FP04jv
R6IlvZRb
R6LCSXn8
R6NT1Syx
R6O8RN67

方案

js-shortid的实现方案很清淅且简单,它由两个字符串够成——时间序号和(多个随机数).

所谓时间序号,就是一个从某个时间点开始按照一定时间间隔有序递增的数字,并用62进制表示。 js-shortid默认的起始时间是2016-04-11 8:00以毫秒为间隔递增,即每一毫秒加1。当然,你可以根据实际需要设置起始时间和递增间隔,如以秒,分,时为间隔进行递增,间隔越大递增就越慢,即ID的时间序号部分变长也会越慢,但同一时间间隔生产的序号是一样的。在高并发或集群中,即便是1毫秒的时间间隔,其序号也是大有可能是一样的。 所以就有了另一部份

所谓,其实是借用了安全领域的术语加盐, 其一般会用于对加密后的密码(如MD5)加盐, 使其不可预测。 而这里也是使产生的短ID不可预测, 由多个随机数组成的字符串,每个随机数以62进制表示, 占两个字符。 加多少取决于你的设置, 默认为两, 即两个盐,占四个字符。 所以,加的越多, 越难预测,同时使短ID更加接近于UUID(全局唯一性ID), 但ID就越长了。

一般来说, 如果时间序号以毫秒递增并加4个,几乎已然就是UUID了。毕竟一毫秒之内随机产生的4个出现一模一样的几乎是不可能的了。

使用

  • node.js
var shortid=require('shortid'); 
console.log(shortid.gen());
  • 浏览器
var sid = shortid.gen();
console.log(sid);

更多点赞,代码,详情请移步Github

最后

重要的东西放在最后。

  1. OK的话,帮加个加星,加星又不会怀孕:github.com/zzzhan/js-shortid

  2. 本文使用自己开发的Markdown Notes进行编辑,推荐大家使用,大家使用,使用,用:md.shapefly.com

相关文章

  • 优雅简洁地实现短ID

    短ID在实际运用中很广泛, 其中比较典型的运用就是短地址。 市面上肯定有不少开源的生成短ID库, 基于node.j...

  • 简洁 | 优雅地整理 BLAST 比对结果

    写在前面 用过 BLAST 进行基因功能注释的朋友应该常常遇到两个问题: BLAST 输出格式较多,选择哪一类输出...

  • Eva: 简洁,优雅的博客系统实现

    就像她的名字,Eva是一个简洁,美观,优雅的博客,我相信所有坚持写用她写博客的人都能找到自己的女神. DEMO (...

  • 简短优雅地利用js实现 sleep 函数

    简短优雅地实现 sleep 函数 很多语言都有 sleep 函数,显然 js 没有,那么如何能简短优雅地实现这个方...

  • python ID混淆-短id

    !/usr/bin/env python -- coding: utf-8 -- ################...

  • 简洁

    简洁 就是优雅 因为 心里不累

  • 如何优雅地使用 Chrome?

    如何优雅地使用Chrome? 何为优雅,我理解的优雅是让你用得更舒心更便捷,所以一切都围绕简洁实用位标准。 第一步...

  • 如何优雅地使用 Git

    如何优雅地使用 Git 版本树 / graph / network 干净简洁清晰 提交信息明确 易维护易读 举个反...

  • 在Kotlin中实现简洁优雅的RxBus

    最近用Kotlin写代码比较多,写的多了真的越来越来喜欢这门语言。作为一门现代化的语言,Kotlin对比Java提...

  • 欧式新娘鲜花造型

    欧式新娘鲜花造型 光洁优雅的低发髻,搭配高耸别致的刘海,再加上鲜花的点缀,整体造型完美地凸显了新娘简洁优雅的气质。...

网友评论

  • 前端开发博客:不太明白这个是用在哪个地方的?
    zzzhan:@前端开发博客 例如这篇文章的地址:
    http://www.jianshu.com/p/ee469e1e1f9d
    其后面的字符串ee469e1e1f9d就可以用这个工具生成,这样是否明白了?:smile:
  • 小众臻品:一个一直困扰我的问题,就算每毫秒产生的4个盐几乎不可能一样,但是还是有可能一样的。那么如何保证绝对唯一呢?(原谅我太钻牛角尖了😁)
    zzzhan:@乖丨摸摸头 最直接了当的做法就是每毫秒生成一个ID,你觉得呢?:smile:

本文标题:优雅简洁地实现短ID

本文链接:https://www.haomeiwen.com/subject/itscdttx.html