JavaScript实现生成GUID(全局统一标识符)


Posted in Javascript onSeptember 05, 2014

GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生成的结果串会比较大。

GUID的格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx

大家都知道GUID在前端开发中用处不大,但如果需要插入某个ID,并且这个ID与后台对应等其它需要GUID的操作时,为了方便,我们还是可以生成一个GUID的。

一般在sql、java、C#等后台或数据库语言中生成GUID都很简单,而前端没有直接生成GUID的方法,只能自己手写一个。但由于GUID需要获取以太网卡的地址、以及纳秒级的时间等数字。而前端获取到这些信息比较困难(知道的童鞋请一定告诉我),而我们可以模拟实现生成GUID,代码如下:

/*
 * 功能:生成一个GUID码,其中GUID以14个以下的日期时间及18个以上的16进制随机数组成,GUID存在一定的重复概率,但重复概率极低,理论上重复概率为每10ms有1/(16^18),即16的18次方分之1,重复概率低至可忽略不计
 * 免责声明:此代码为作者学习专用,如在使用者在使用过程中因代码问题造成的损失,与作者没有任何关系
 * 日期:2014年9月4日
 * 作者:wyc
 */

 
function GUID() {
  this.date = new Date();

  /* 判断是否初始化过,如果初始化过以下代码,则以下代码将不再执行,实际中只执行一次 */
  if (typeof this.newGUID != 'function') {
    
    /* 生成GUID码 */
    GUID.prototype.newGUID = function() {
      this.date = new Date();
      var guidStr = '';
        sexadecimalDate = this.hexadecimal(this.getGUIDDate(), 16);
        sexadecimalTime = this.hexadecimal(this.getGUIDTime(), 16);
      for (var i = 0; i < 9; i++) {
        guidStr += Math.floor(Math.random()*16).toString(16);
      }
      guidStr += sexadecimalDate;
      guidStr += sexadecimalTime;
      while(guidStr.length < 32) {
        guidStr += Math.floor(Math.random()*16).toString(16);
      }
      return this.formatGUID(guidStr);
    }

    /*
     * 功能:获取当前日期的GUID格式,即8位数的日期:19700101
     * 返回值:返回GUID日期格式的字条串
     */
    GUID.prototype.getGUIDDate = function() {
      return this.date.getFullYear() + this.addZero(this.date.getMonth() + 1) + this.addZero(this.date.getDay());
    }

    /*
     * 功能:获取当前时间的GUID格式,即8位数的时间,包括毫秒,毫秒为2位数:12300933
     * 返回值:返回GUID日期格式的字条串
     */
    GUID.prototype.getGUIDTime = function() {
      return this.addZero(this.date.getHours()) + this.addZero(this.date.getMinutes()) + this.addZero(this.date.getSeconds()) + this.addZero( parseInt(this.date.getMilliseconds() / 10 ));
    }

    /*
    * 功能: 为一位数的正整数前面添加0,如果是可以转成非NaN数字的字符串也可以实现
     * 参数: 参数表示准备再前面添加0的数字或可以转换成数字的字符串
     * 返回值: 如果符合条件,返回添加0后的字条串类型,否则返回自身的字符串
     */
    GUID.prototype.addZero = function(num) {
      if (Number(num).toString() != 'NaN' && num >= 0 && num < 10) {
        return '0' + Math.floor(num);
      } else {
        return num.toString();
      }
    }

    /* 
     * 功能:将y进制的数值,转换为x进制的数值
     * 参数:第1个参数表示欲转换的数值;第2个参数表示欲转换的进制;第3个参数可选,表示当前的进制数,如不写则为10
     * 返回值:返回转换后的字符串
     */
    GUID.prototype.hexadecimal = function(num, x, y) {
      if (y != undefined) {
        return parseInt(num.toString(), y).toString(x);
      } else {
        return parseInt(num.toString()).toString(x);
      }
    }

    /*
     * 功能:格式化32位的字符串为GUID模式的字符串
     * 参数:第1个参数表示32位的字符串
     * 返回值:标准GUID格式的字符串
     */
    GUID.prototype.formatGUID = function(guidStr) {
      var str1 = guidStr.slice(0, 8) + '-',
        str2 = guidStr.slice(8, 12) + '-',
        str3 = guidStr.slice(12, 16) + '-',
        str4 = guidStr.slice(16, 20) + '-',
        str5 = guidStr.slice(20);
      return str1 + str2 + str3 + str4 + str5;
    }
  }
}

GUID 对象

只需要将其保存在一个JS文件中并引用即可。

然后我们只需要。

var guid = new GUID();


alert(guid.newGUID()); 

即可获取GUID码。

实现原理很简单,这里只是采用了系统时间与18个以上的十六进制随机数组成,并用系统时间转换为十六进制,这样虽然还是有可能重复,但是重复的概率极低,可忽略不计。

以上为本人写的生成GUID的方法,如有更好的方法可以告诉我,谢谢!

Javascript 相关文章推荐
使用prototype.js 的时候应该特别注意的几个问题.
Apr 12 Javascript
基于jquery的图片的切换(以数字的形式)
Feb 14 Javascript
jquery高效反选具体实现
May 05 Javascript
javascript和HTML5利用canvas构建猜牌游戏实现算法
Jul 17 Javascript
浅析jquery的作用与优势
Dec 02 Javascript
JavaScript支持的最大递归调用次数分析
Jun 24 Javascript
AngularJS学习笔记之TodoMVC的分析
Feb 22 Javascript
JS操作XML实例总结(加载与解析XML文件、字符串)
Dec 08 Javascript
动态更新highcharts数据的实现方法
May 28 Javascript
Vue请求JSON Server服务器数据的实现方法
Nov 02 Javascript
vuex actions异步修改状态的实例详解
Nov 06 Javascript
浅谈vue的第一个commit分析
Jun 08 Javascript
JavaScript判断textarea值是否为空并给出相应提示
Sep 04 #Javascript
Firefox下无法正常显示年份的解决方法
Sep 04 #Javascript
window.location的重写及判断location是否被重写
Sep 04 #Javascript
js怎么覆盖原有方法实现重写
Sep 04 #Javascript
JS的location.href跳出框架打开新页面的方法
Sep 04 #Javascript
手机号码,密码正则验证
Sep 04 #Javascript
javascript中2个感叹号的用法实例详解
Sep 04 #Javascript
You might like
二十行语句实现从Excel到mysql的转化
2006/10/09 PHP
php mssql 数据库分页SQL语句
2008/12/16 PHP
PHP容易忘记的知识点分享
2013/04/30 PHP
PHP连接MySQL数据的操作要点
2015/03/20 PHP
PHP链表操作简单示例
2016/10/15 PHP
PHP实现负载均衡session共享redis缓存操作示例
2018/08/22 PHP
javascript编程起步(第六课)
2007/02/27 Javascript
我的javascript 函数链之演变
2011/04/07 Javascript
JavaScript禁止页面操作的示例代码
2013/12/17 Javascript
Javascript基础教程之函数对象和属性
2015/01/18 Javascript
JavaScript中实现无缝滚动、分享到侧边栏实例代码
2016/04/06 Javascript
bootstrap按钮插件(Button)使用方法解析
2017/01/13 Javascript
Javascript中document.referrer隐藏来源的方法
2017/01/16 Javascript
boostrapTable的refresh和refreshOptions区别浅析
2017/01/22 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
2017/02/20 Javascript
微信小程序实现评论功能
2018/11/28 Javascript
Python中的CURL PycURL使用例子
2014/06/01 Python
Python程序设计入门(3)数组的使用
2014/06/16 Python
Python脚本文件打包成可执行文件的方法
2015/06/02 Python
Python实现的字典排序操作示例【按键名key与键值value排序】
2018/12/21 Python
解决pyqt5中QToolButton无法使用的问题
2019/06/21 Python
pandas实现to_sql将DataFrame保存到数据库中
2019/07/03 Python
自适应线性神经网络Adaline的python实现详解
2019/09/30 Python
PyTorch中Tensor的数据类型和运算的使用
2020/09/03 Python
Jupyter notebook命令和编辑模式常用快捷键汇总
2020/11/17 Python
一个入门级python爬虫教程详解
2021/01/27 Python
用React加CSS3实现微信拆红包动画效果
2017/03/13 HTML / CSS
前后端结合实现amazeUI分页效果
2020/08/21 HTML / CSS
英国户外服装品牌:Craghoppers
2019/04/25 全球购物
德国受欢迎的旅游和休闲网站:lastminute.de
2019/09/23 全球购物
在线实验室测试:HealthLabs.com
2020/05/03 全球购物
比较基础的php面试题及答案-编程题
2012/10/14 面试题
公务员平时考核实施方案
2014/03/11 职场文书
读书小明星事迹材料
2014/05/03 职场文书
员工合理化建议书
2014/05/19 职场文书
教师工作态度自我评价
2015/03/05 职场文书