PHP如何生成唯一uid,什么事项要注意
Admin 2022-05-25 群英技术资讯 1060 次浏览
这篇文章主要讲解了“PHP如何生成唯一uid,什么事项要注意”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。看到某些人会用uuid去代替用户的uid
从代码中可以看出,通过unique生成一个以毫秒级时间戳为前缀的字符后md5加密
再通过分隔符进行分割后得到uuid
这种方式虽然极大程度的避免了uid的重复
但是生成的uid太长,足足36个字符,而且是混杂英文和数字符号的,可读性很差
而一般的uid中都是纯数值组成的
<?php
function generateUUid($strtoupper = false)
{
$charid = call_user_func($strtoupper ? 'strtoupper' : 'strtolower', md5(uniqid(microtime(true), true)));
$hyphen = chr(45);
$uuid = substr($charid, 0, 8) . $hyphen . substr($charid, 8, 4) . $hyphen . substr($charid, 12, 4) . $hyphen . substr($charid, 16, 4) . $hyphen . substr($charid, 20, 12);
return $uuid;
}
//结果:37f14a07-cb18-2e54-4e40-da1e2fa0456d
由于一般正常的uid都是纯数值型的
而要保证唯一性,必然要跟时间戳有关系,因此有了以下代码
为了尽可能的在同一秒中注册人数的uid不同,将时间戳进行打乱随机排序,也不失为一个好办法
但是这种缺点就是,uid长度是固定的,无法进行改变,虽然呢,打乱字符是一个很好的解决重复的方式
但是事情无绝对,如果真的因为随机碰撞导致的uid相同该如何
为了更保险起见,必然还是要走一次数据库的查询
大大增加了数据库的I/O压力
<?php
function generateUid()
{
return call_user_func('str_shuffle', time());
}
//结果:4067524162
虽然说上面的两种方式并非不可取
但是在大型公司必然不可取,一种是uid的格式必然纯数值,所以uuid方式可以排除
另外由于对数据库的压力起见,必然也不会采用第二种方式
而最经常采用的方式应该是使用数据库的主键索引,因为主键索引必然唯一
这里很多人会疑惑,主键索引不是会从1开始吗,这uid会有1位数的?
小了,格局小了,你可以设置主键索引的offset,让他从100000开始,不就可以解决这个问题了吗
这时候有人又问,那主键索引增加不是有规律的吗,比如插一条,会自增1
这时候就可以设置主键索引的增长步长,让他插入一条的步长不为1即可
而为了让uid看起来更加没有关联性,你可以设置步长为基数,比如3
这样增长起来,就会是100000,100003,100006,100009,100012....

php中生成标准uuid的方法
UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。
通常平台 会提供生成UUID的API。UUID按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。
由以 下几部分的组合:当前日期和时间(UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相 同),时钟序列,全局唯一的IEEE机器识别号(如果有网卡,从网卡获得,没有网卡以其他方式获得),UUID的唯一缺陷在于生成的结果串会比较长。
关于 UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers)。
在ColdFusion中可以用CreateUUID()函数很简单的生成UUID,其格式为:xxxxxxxx-xxxx-xxxx- xxxxxxxxxxxxxxxx(8-4-4-16),其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。
而标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx (8-4-4-4-12)
<?php
function guid(){
if (function_exists('com_create_guid')){
return com_create_guid();
}else{
mt_srand((double)microtime()*10000);//optional for php 4.2.0 and up.
$charid = strtoupper(md5(uniqid(rand(), true)));
$hyphen = chr(45);// "-"
$uuid = chr(123)// "{"
.substr($charid, 0, 8).$hyphen
.substr($charid, 8, 4).$hyphen
.substr($charid,12, 4).$hyphen
.substr($charid,16, 4).$hyphen
.substr($charid,20,12)
.chr(125);// "}"
return $uuid;
}
}
echo guid();
?>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
现在很多网站和软件的注册都会让用户填写电话号码,之后系统会向用户手机发送一条短信验证码,用户输入验证码之后就能正常使用了,而且还能使用短信验证码进行快捷登录。很多朋友会注意到,我们获取短信验证码是有时间隔或者或缺次数的,那么这些限制是如何实现的呢?这篇文章就给大家分享一下对使用PHP实现的短信验证发送次数限制。
今天小编就为大家分享一篇laravel 实现根据字段不同值做不同查询,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
在本部分,你将了解 PHP5 的目录函数:Directory 函数。有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
验证邮箱格式是否正确可以通过filter_var函数来实现。下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
json_decode是php5.2.0之后新增的一个PHP内置函数,其作用是对JSON格式的字符串进行编码。下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008