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; }
当然了,个人还是推荐算法一的,小伙伴们可以根据自己的需求来进行选择。