分享一个网上找的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)); } ;
分享一个网上找的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));
}
解释
-
generatorUUID 函数:
- 使用了
Date
对象来计算时间戳。 getIntegerBits
函数用来截取时间戳的特定部分。rand
函数生成随机数,用于增加UUID的唯一性。- 最终将各个部分拼接成一个32位的UUID字符串。
- 使用了
-
getIntegerBits 函数:
- 将传入的数值转换为16进制字符串。
- 截取并拼接指定范围内的位,返回一个字符串形式的结果。
-
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());
解释:
- 时间戳部分:使用了从1582年到当前时间的时间差来生成UUID的前几部分。
- 版本信息:在
thv
中添加了0x4000
以表示这是版本1的UUID。 - 随机数部分:通过多次调用
Math.random()
并转换为16进制字符串来生成随机数。 - 格式化:使用
.toString(16)
将数字转换为16进制字符串,并用00
填充以确保每个部分都是固定长度。
这段代码可以生成一个符合标准的32位UUID。