分享一个网上找的Nodejs创建UUID的源码

分享一个网上找的Nodejs创建UUID的源码

Blockquote /**

  • 产生32位的UUID
  • Created with JetBrains WebStorm.
  • User: Administrator
  • Date: 12-10-24
  • Time: 下午4:48
  • To change this template use File | Settings | File Templates. */

// // INSTANCE SPECIFIC METHODS // exports.generatorUUID=function() { // // Loose interpretation of the specification DCE 1.1: Remote Procedure Call // since JavaScript doesn’t allow access to internal systems, the last 48 bits // of the node section is made up using a series of random numbers (6 octets long). // var dg = new Date(1582, 10, 15, 0, 0, 0, 0); var dc = new Date(); var t = dc.getTime() - dg.getTime(); var tl = getIntegerBits(t, 0, 31); var tm = getIntegerBits(t, 32, 47); var thv = getIntegerBits(t, 48, 59) + ‘1’; // version 1, security version is 2 var csar = getIntegerBits(rand(4095), 0, 7); var csl = getIntegerBits(rand(4095), 0, 7);

// since detection of anything about the machine/browser is far to buggy,
// include some more random numbers here
// if NIC or an IP can be obtained reliably, that should be put in
// here instead.
var n = getIntegerBits(rand(8191), 0, 7) +
    getIntegerBits(rand(8191), 8, 15) +
    getIntegerBits(rand(8191), 0, 7) +
    getIntegerBits(rand(8191), 8, 15) +
    getIntegerBits(rand(8191), 0, 15); // this last number is two octets long
return tl + tm + thv + csar + csl + n;

} ;

//Pull out only certain bits from a very large integer, used to get the time //code information for the first part of a UUID. Will return zero’s if there //aren’t enough bits to shift where it needs to. function getIntegerBits(val, start, end) { var base16 = returnBase(val, 16); var quadArray = new Array(); var quadString = ‘’; var i = 0; for (i = 0; i < base16.length; i++) { quadArray.push(base16.substring(i, i + 1)); } for (i = Math.floor(start / 4); i <= Math.floor(end / 4); i++) { if (!quadArray[i] || quadArray[i] == ‘’) quadString += ‘0’; else quadString += quadArray[i]; } return quadString; } ;

//Replaced from the original function to leverage the built in methods in //JavaScript. Thanks to Robert Kieffer for pointing this one out function returnBase(number, base) { return (number).toString(base).toUpperCase(); } ;

//pick a random number within a range of numbers //int b rand(int a); where 0 <= b <= a function rand(max) { return Math.floor(Math.random() * (max + 1)); } ;


3 回复

分享一个网上找的Nodejs创建UUID的源码

概述

在这个帖子中,我们将分享一段用于生成32位UUID的Node.js代码。这段代码采用了DCE 1.1规范中的部分内容,并通过一些随机数生成机制来模拟机器或网络信息。

代码示例

/**
 * 产生32位的UUID
 * Created with JetBrains WebStorm.
 * User: Administrator
 * Date: 12-10-24
 * Time: 下午4:48
 */

// 实例特定的方法
exports.generatorUUID = function () {
    // 使用新的日期对象作为时间戳的基础
    var dg = new Date(1582, 10, 15, 0, 0, 0, 0);
    var dc = new Date();
    var t = dc.getTime() - dg.getTime();

    // 获取时间戳的各个部分
    var tl = getIntegerBits(t, 0, 31);
    var tm = getIntegerBits(t, 32, 47);
    var thv = getIntegerBits(t, 48, 59) + '1'; // 版本1,安全版本为2
    var csar = getIntegerBits(rand(4095), 0, 7);
    var csl = getIntegerBits(rand(4095), 0, 7);

    // 添加随机数以增加唯一性
    var n = getIntegerBits(rand(8191), 0, 7) +
        getIntegerBits(rand(8191), 8, 15) +
        getIntegerBits(rand(8191), 0, 7) +
        getIntegerBits(rand(8191), 8, 15) +
        getIntegerBits(rand(8191), 0, 15); // 这个数字是两个八位字节长

    // 返回拼接后的UUID字符串
    return tl + tm + thv + csar + csl + n;
};

// 从一个很大的整数中提取特定的位,用于获取UUID前部分的时间码信息
function getIntegerBits(val, start, end) {
    var base16 = val.toString(16);
    var quadArray = [];
    var quadString = '';

    for (var i = 0; i < base16.length; i++) {
        quadArray.push(base16[i]);
    }

    for (var i = Math.floor(start / 4); i <= Math.floor(end / 4); i++) {
        if (!quadArray[i]) quadString += '0';
        else quadString += quadArray[i];
    }

    return quadString;
}

// 随机数生成函数
function rand(max) {
    return Math.floor(Math.random() * (max + 1));
}

解释

  1. generatorUUID 函数:

    • 使用了 Date 对象来计算时间戳。
    • getIntegerBits 函数用来截取时间戳的特定部分。
    • rand 函数生成随机数,用于增加UUID的唯一性。
    • 最终将各个部分拼接成一个32位的UUID字符串。
  2. getIntegerBits 函数:

    • 将传入的数值转换为16进制字符串。
    • 截取并拼接指定范围内的位,返回一个字符串形式的结果。
  3. rand 函数:

    • 生成一个介于0到最大值之间的随机整数。

通过上述代码,我们可以生成一个32位的UUID,虽然这种方法并不是最标准的UUID生成方法(如RFC 4122),但在某些应用场景下仍然有效。


楼主参考这两份文档标记一下格式吧… 看着相当辛苦啊 http://wowubuntu.com/markdown/ http://github.github.com/github-flavored-markdown/

以下是一个简洁的 Node.js 示例代码,用于生成32位的UUID。该代码使用了JavaScript内置的方法来简化一些复杂的操作,并且更加易于理解和维护。

const generateUUID = () => {
    const dg = new Date(1582, 10, 15, 0, 0, 0, 0);
    const dc = new Date();
    const t = dc.getTime() - dg.getTime();
    
    const tl = ('00000000' + t.toString(16)).slice(-8);
    const tm = ('0000' + ((t / 4294967296) | 0).toString(16)).slice(-4);
    const thv = ('000' + (((t % 4294967296) >>> 12) | 0x4000).toString(16)).slice(-4);
    const csar = ('00' + (Math.random() * 4096 | 0).toString(16)).slice(-4);
    const csl = ('0000' + (Math.random() * 4096 | 0).toString(16)).slice(-4);

    // 添加一些随机数以确保UUID的唯一性
    const n = ('00' + (Math.random() * 4096 | 0).toString(16)).slice(-4) +
              ('00' + (Math.random() * 4096 | 0).toString(16)).slice(-4) +
              ('0000' + (Math.random() * 65536 | 0).toString(16)).slice(-4);

    return tl + tm + thv + csar + csl + n;
};

console.log(generateUUID());

解释:

  1. 时间戳部分:使用了从1582年到当前时间的时间差来生成UUID的前几部分。
  2. 版本信息:在thv中添加了0x4000以表示这是版本1的UUID。
  3. 随机数部分:通过多次调用Math.random()并转换为16进制字符串来生成随机数。
  4. 格式化:使用.toString(16)将数字转换为16进制字符串,并用00填充以确保每个部分都是固定长度。

这段代码可以生成一个符合标准的32位UUID。

回到顶部