Javascript生成全局唯一标识符(GUID,UUID)的方法
全局唯一标识符(GUID,GloballyUniqueIdentifier)也称作UUID(UniversallyUniqueIDentifier)。
GUID是一种由算法生成的二进制长度为128位的数字标识符。GUID的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中的x是0-9或a-f范围内的一个32位十六进制数。在理想情况下,任何计算机和计算机集群都不会生成两个相同的GUID。
GUID的总数达到了2^128(3.4×10^38)个,所以随机生成两个相同GUID的可能性非常小,但并不为0。GUID一词有时也专指微软对UUID标准的实现。
在生成一些节点的时候需要通过唯一ID来标记,有如下高票答案可供参考
functiongenerateUUID(){
vard=newDate().getTime();
varuuid='xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g,function(c){
varr=(d+Math.random()*16)%16|0;
d=Math.floor(d/16);
return(c=='x'?r:(r&0x3|0x8)).toString(16);
});
returnuuid;
};
答案下面的评论云:这个方案下的碰撞率不及1/2^^122
另外给大家推荐几种算法
算法2
functionguid(){
return'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g,function(c){
varr=Math.random()*16|0,v=c=='x'?r:(r&0x3|0x8);
returnv.toString(16);
});
}
算法3
functionguid(){
functionS4(){
return(((1+Math.random())*0x10000)|0).toString(16).substring(1);
}
return(S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4());
}
算法4
functionuuid(len,radix){
varchars='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');
varuuid=[],i;
radix=radix||chars.length;
if(len){
//Compactform
for(i=0;i<len;i++)uuid[i]=chars[0|Math.random()*radix];
}else{
//rfc4122,version4form
varr;
//rfc4122requiresthesecharacters
uuid[8]=uuid[13]=uuid[18]=uuid[23]='-';
uuid[14]='4';
//Fillinrandomdata.Ati==19setthehighbitsofclocksequenceas
//perrfc4122,sec.4.1.5
for(i=0;i<36;i++){
if(!uuid[i]){
r=0|Math.random()*16;
uuid[i]=chars[(i==19)?(r&0x3)|0x8:r];
}
}
}
returnuuid.join('');
}
这个可以指定长度和基数。比如
//8characterID(base=2) uuid(8,2)//"01001010" //8characterID(base=10) uuid(8,10)//"47473046" //8characterID(base=16) uuid(8,16)//"098F4D35"
算法5
functionuuid(){
vars=[];
varhexDigits="0123456789abcdef";
for(vari=0;i<36;i++){
s[i]=hexDigits.substr(Math.floor(Math.random()*0x10),1);
}
s[14]="4";//bits12-15ofthetime_hi_and_versionfieldto0010
s[19]=hexDigits.substr((s[19]&0x3)|0x8,1);//bits6-7oftheclock_seq_hi_and_reservedto01
s[8]=s[13]=s[18]=s[23]="-";
varuuid=s.join("");
returnuuid;
}
当然了,个人还是推荐算法一的,小伙伴们可以根据自己的需求来进行选择。