ckeditor5/utils:uid——基于js的幾種uuid算法

UUID(Universally Unique Identifier) 是長為 128 bits 的通用唯一識別碼冀瓦,它由 RFC 4122 定義调鲸,最早被用于阿波羅網(wǎng)絡計算系統(tǒng)(Apollo Network Computing System) 和微軟的 Windows 平臺,如今 OpenStack 也廣泛的使用它來標志計算焰扳、存儲和網(wǎng)絡等資源倦零。UUID 的目的,是讓分布式系統(tǒng)中的所有元素蓝翰,都能有唯一的辨識信息光绕,而不需要通過中央控制端來做辨識信息。本文主要介紹 UUID 的生成算法畜份,并且解釋它為什么能保證全局唯一诞帐。
為便于表示,UUID 標準型式包含 32 個 16 進制數(shù)字爆雹,以連字號分為五段停蕉,形式為 8-4-4-4-12 的 32 個字符,例如:f81d4fae-7dec-11d0-a765-00a0c91e6bf6

1.node-uuid

下面的代碼是從node-uuid的v4算法簡化而得:

var _rnds = new Array(16);
var _byteToHex = [];
for (var i = 0; i < 256; i++) {
  _byteToHex[i] = (i + 0x100).toString(16).substr(1);
}

var _rng = function() {
  for (var i = 0, r; i < 16; i++) {
    if ((i & 0x03) === 0) { r = Math.random() * 0x100000000; }
    _rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;
  }

  return _rnds;
};

function unparse(buf) {
  var i = 0, bth = _byteToHex;
  return  bth[buf[i++]] + bth[buf[i++]] +
          bth[buf[i++]] + bth[buf[i++]] + '-' +
          bth[buf[i++]] + bth[buf[i++]] + '-' +
          bth[buf[i++]] + bth[buf[i++]] + '-' +
          bth[buf[i++]] + bth[buf[i++]] + '-' +
          bth[buf[i++]] + bth[buf[i++]] +
          bth[buf[i++]] + bth[buf[i++]] +
          bth[buf[i++]] + bth[buf[i++]];
}


function v4() {
  // Deprecated - 'format' argument, as supported in v1.2
  var i = 0;

  var rnds = _rng();

  // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
  rnds[6] = (rnds[6] & 0x0f) | 0x40;
  rnds[8] = (rnds[8] & 0x3f) | 0x80;

  return unparse(rnds);
}
// 執(zhí)行
console.log(v4()); // e28427a9-f6ea-43f3-894d-ac9e48aaad49 // 去掉四個“-”后钙态,還剩下32位

2.ckeditor5 uid.js

// A hash table of hex numbers to avoid using toString() in uid() which is costly.
// [ '00', '01', '02', ..., 'fe', 'ff' ]
const HEX_NUMBERS = new Array( 256 ).fill()
    .map( ( val, index ) => ( '0' + ( index ).toString( 16 ) ).slice( -2 ) );

/**
 * Returns a unique id. The id starts with an "e" character and a randomly generated string of
 * 32 alphanumeric characters.
 *
 * **Note**: The characters the unique id is built from correspond to the hex number notation
 * (from "0" to "9", from "a" to "f"). In other words, each id corresponds to an "e" followed
 * by 16 8-bit numbers next to each other.
 *
 * @returns {String} An unique id string.
 */
function uid() {
    // Let's create some positive random 32bit integers first.
    //
    // 1. Math.random() is a float between 0 and 1.
    // 2. 0x100000000 is 2^32 = 4294967296.
    // 3. >>> 0 enforces integer (in JS all numbers are floating point).
    //
    // For instance:
    //      Math.random() * 0x100000000 = 3366450031.853859
    // but
    //      Math.random() * 0x100000000 >>> 0 = 3366450031.
        // >>> 0可以保證是正數(shù)
    const r1 = Math.random() * 0x100000000 >>> 0;
    const r2 = Math.random() * 0x100000000 >>> 0;
    const r3 = Math.random() * 0x100000000 >>> 0;
    const r4 = Math.random() * 0x100000000 >>> 0;

    // Make sure that id does not start with number.
        // 跟0xFF的與操作可以確保只取8位慧起,這樣確保從HEX_NUMBERS取到值
    return 'e' +
        HEX_NUMBERS[ r1 >> 0 & 0xFF ] +
        HEX_NUMBERS[ r1 >> 8 & 0xFF ] +
        HEX_NUMBERS[ r1 >> 16 & 0xFF ] +
        HEX_NUMBERS[ r1 >> 24 & 0xFF ] +
        HEX_NUMBERS[ r2 >> 0 & 0xFF ] +
        HEX_NUMBERS[ r2 >> 8 & 0xFF ] +
        HEX_NUMBERS[ r2 >> 16 & 0xFF ] +
        HEX_NUMBERS[ r2 >> 24 & 0xFF ] +
        HEX_NUMBERS[ r3 >> 0 & 0xFF ] +
        HEX_NUMBERS[ r3 >> 8 & 0xFF ] +
        HEX_NUMBERS[ r3 >> 16 & 0xFF ] +
        HEX_NUMBERS[ r3 >> 24 & 0xFF ] +
        HEX_NUMBERS[ r4 >> 0 & 0xFF ] +
        HEX_NUMBERS[ r4 >> 8 & 0xFF ] +
        HEX_NUMBERS[ r4 >> 16 & 0xFF ] +
        HEX_NUMBERS[ r4 >> 24 & 0xFF ];
}
console.log(uid()); // e80d81d97cc24b8b8bf6e2e7083167489,去掉開頭的e字母后册倒,還剩32位

其他

function uuid() {
    var s = [];
    var hexDigits = "0123456789abcdef";
    for (var i = 0; i < 36; i++) {
        s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
    }
    // bits 12-15 of the time_hi_and_version field to 0010 
    s[14] = "4";
    // bits 6-7 of the clock_seq_hi_and_reserved to 01
    s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1);
    s[8] = s[13] = s[18] = s[23] = "-";
 
    var uuid = s.join("");
    return uuid;
}
console.log(uuid()) // ea95751c-ccd0-418e-aac3-6bc408b76689

參考

理解 UUID

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚓挤,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子驻子,更是在濱河造成了極大的恐慌灿意,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崇呵,死亡現(xiàn)場離奇詭異缤剧,居然都是意外死亡,警方通過查閱死者的電腦和手機域慷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進店門荒辕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來汗销,“玉大人,你說我怎么就攤上這事抵窒〕谡耄” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵估脆,是天一觀的道長钦奋。 經(jīng)常有香客問我,道長疙赠,這世上最難降的妖魔是什么付材? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮圃阳,結果婚禮上厌衔,老公的妹妹穿的比我還像新娘。我一直安慰自己捍岳,他們只是感情好富寿,可當我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著锣夹,像睡著了一般页徐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上银萍,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天变勇,我揣著相機與錄音,去河邊找鬼贴唇。 笑死搀绣,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的戳气。 我是一名探鬼主播链患,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瓶您!你這毒婦竟也來了麻捻?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤呀袱,失蹤者是張志新(化名)和其女友劉穎芯肤,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體压鉴,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年锻拘,在試婚紗的時候發(fā)現(xiàn)自己被綠了油吭。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片击蹲。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖婉宰,靈堂內(nèi)的尸體忽然破棺而出歌豺,到底是詐尸還是另有隱情,我是刑警寧澤心包,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布类咧,位于F島的核電站,受9級特大地震影響蟹腾,放射性物質(zhì)發(fā)生泄漏痕惋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一娃殖、第九天 我趴在偏房一處隱蔽的房頂上張望值戳。 院中可真熱鬧,春花似錦炉爆、人聲如沸堕虹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赴捞。三九已至,卻和暖如春郁稍,著一層夾襖步出監(jiān)牢的瞬間赦政,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工艺晴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留昼钻,地道東北人。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓封寞,卻偏偏與公主長得像然评,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子狈究,可洞房花燭夜當晚...
    茶點故事閱讀 45,685評論 2 360