php 自动生成12位数字_php生成12位不重复数字字母组合会员卡号

在不查询数据库的情况下,每个会员登录进来会生成一个数字字母组合不重复的会员卡号。

回复讨论(解决方案)

function generate_password( $length = 12 ) { $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; $password = ''; for ( $i = 0; $i < $length; $i++ ) { $password .= $chars[ mt_rand(0, strlen($chars) - 1) ]; } return $password;}echo generate_password(12);

$alpha_numeric = 'abcdefghijklmnopqrstuvwxyz01234567890';

echo substr(str_shuffle($alpha_numeric),0,2).strtotime("now");

时间戳+session id hash算出就行了

按相同规则/顺序拆分组合就是了

办法方法很多,比如算个GUID再弄个md5再sha1再截取12位...呵呵

让人最容易想到的是使用随机数,但是你无法证明两次的结果一定不相同

MD5产生32位的结果串并且已经证明了MD5存在“碰撞”:两个不同的内容具有相同的MD5值

同样你也无法证明截断后的MD5值与原串具有相同的唯一性

因此还是使用时间作为参数比较稳妥function foo() { $o = $last = ''; do { $last = $o; usleep(10); $t = explode(' ', microtime()); $o = substr(base_convert(strtr($t[0].$t[1].$t[1], '.', ''), 10, 36), 0, 12); }while($o == $last); return $o;}当然,这个生成算法同样具有局限性。12位的36进制数最多有 pow(36, 12) 种状态

当总量超过 pow(36, 12) 时,重复还是必然发生的

让人最容易想到的是使用随机数,但是你无法证明两次的结果一定不相同

MD5产生32位的结果串并且已经证明了MD5存在“碰撞”:两个不同的内容具有相同的MD5值

同样你也无法证明截断后的MD5值与原串具有相同的唯一性

因此还是使用时间作为参数比较稳妥function foo() { $o = $last = ''; do { $last = $o; usleep(10); $t = explode(' ', microtime()); $o = substr(base_convert(strtr($t[0].$t[1].$t[1], '.', ''), 10, 36), 0, 12); }while($o == $last); return $o;}当然,这个生成算法同样具有局限性。12位的36进制数最多有 pow(36, 12) 种状态

当总量超过 pow(36, 12) 时,重复还是必然发生的

版主说的有道理!1楼的方法怎么样?

版主,这句是不是写错了? $o = substr(base_convert(strtr($t[0].$t[1].$t[1], '.', ''), 10, 36), 0, 12);

#1 使用的是随机数,在同一次运行中多次调用是不会有问题的

但不能保证在程序多次运行时没有问题

$o = substr(base_convert(strtr($t[0].$t[1].$t[1], '.', ''), 10, 36), 0, 12);

没有错

$t = explode(' ', microtime());

后 $t[0] 是实践的小数部分,$t[1]是时间的正数部分

由于小数部分的长度不一,会导致不能确保结果的 12 位

或许直接扩展小数部分的长度要好一些

程序报错了!你测试一下!

怎么可能?

请你把错误信息贴全了

另外 41 行你写成什么了?怎么看不见?

请你把错误信息贴全了

另外 41 行你写成什么了?怎么看不见?

解决了!我直接从你那粘贴过来有空格。$o=substr(base_convert(strtr($t[0].$t[1].$t[1], '.' ,''), 10, 36), 0, 12);

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值