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

效果图如下:

当我们要将一个庞大的数据进行编号时,而编号有位数限制,比如5位的车牌号、10位的某证件号码、订单流水号、短网址等等,我们可以使用36进制计算出符合位数的不重复的编号。

我们将0-Z(0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ)分别代表数值0-35,如字母Z代表35。这样的话我要得到一个5位的编号,最大信息量就是36的5次方了,36^5 = 60466176,即最大的5位编号相当于10进制的数字:60466176。

本文中为了做演示,我们假定某俱乐部发放一批10位的会员卡号,会员卡号由3位城市编号+5位卡号编码+2位校验码组成。城市编号用区号表示,如755代表深圳,5位卡编号则由36进制的卡编号组成,后面两位校验码则是通过一定的算法生成的,校验码的用处是可以验证卡号的合法性。这样的话,我们生成的10位卡号相当于最大能满足6000多万会员卡号,并且是不重复唯一的卡号。

PHP

我们使用PHP进行进制转换,10进制转36进制。class Code {

//密码字典

private $dic = array(

0=>'0', 1=>'1', 2=>'2', 3=>'3', 4=>'4', 5=>'5', 6=>'6', 7=>'7', 8=>'8',

9=>'9', 10=>'A', 11=>'B', 12=>'C', 13=>'D', 14=>'E', 15=>'F', 16=>'G', 17=>'H',

18=>'I',19=>'J', 20=>'K', 21=>'L', 22=>'M', 23=>'N', 24=>'O', 25=>'P', 26=>'Q',

27=>'R',28=>'S', 29=>'T', 30=>'U', 31=>'V', 32=>'W', 33=>'X', 34=>'Y', 35=>'Z'

);

public function encodeID($int, $format=8) {

$dics = $this->dic;

$dnum = 36; //进制数

$arr = array ();

$loop = true;

while ($loop) {

$arr[] = $dics[bcmod($int, $dnum)];

$int = bcdiv($int, $dnum, 0);

if ($int == '0') {

$loop = false;

}

}

if (count($arr) < $format)

$arr = array_pad($arr, $format, $dics[0]);

return implode('', array_reverse($arr));

}

public function decodeID($ids) {

$dics = $this->dic;

$dnum = 36; //进制数

//键值交换

$dedic = array_flip($dics);

//去零

$id = ltrim($ids, $dics[0]);

//反转

$id = strrev($id);

$v = 0;

for ($i = 0, $j = strlen($id); $i < $j; $i++) {

$v = bcadd(bcmul($dedic[$id {

$i }

], bcpow($dnum, $i, 0), 0), $v, 0);

}

return $v;

}

}

我们定义Code类,先定义密码字典,即0-Z分别对应的数值,方法encodeID($int, $format)中参数$int表示数字,$format表示位数长度,比方encodeID(123456789,5)表示将数字123456789转换成5位的36进制编号,而方法decodeID($ids)用于将36进制的编号转换成10进制的编号。

我们可以这样来生成卡号:$code = new Code(); $card_no = $code->encodeID(888888,5);

如上,我们就可以得到一个5位的卡编号,它实际代表着卡号是888888(6个8)的会员编号,而实际进行转换后是5位编号:0J1VC。

接着,我们将城市编号和校验码加上,城市编号是已经定义好的,校验码则通过一定的算法取得,本例中,我们使用简单的算法:将前三位城市编号和五位卡编号进行md5加密,然后取md5值的前2位作为校验码,这样就得到了编号后面的两位校验码。$card_pre = '755';

$card_vc = substr(md5($card_pre.$card_no),0,2);

$card_vc = strtoupper($card_vc);

echo $card_pre.$card_no.$card_vc;

实际应用中,可以通过数据库得到10进制的编号,保证编号唯一,再将上述代码组合,最终生成一个10位的不重复的会员卡号。

php如何生成唯一随机数,PHP实现生成唯一会员卡号(不重复的随机数)相关推荐

  1. python随机生成k个不重复的随机数_使用Python生成不重复的随机值

    uuid是128位的全局唯一标识符(univeral unique identifier),通常用32位的一个字符串的形式来表现,自带了uuid模块来进行uuid的生成和管理工作. python中的u ...

  2. 如何生成指定范围不重复的随机数数组

    如何生成指定范围不重复的随机数数组 例如:输入m=10,n=20 输出结果:[14, 11, 18, 12, 19, 20, 13, 15, 17, 16, 10](结果不唯一,满足条件即可) 程序源 ...

  3. 随机数与随机序列生成

    随机数与随机序列生成 随机数的生成 · 通过rand()函数生成随机数 · 通过多个随机数拼接生成随机数 随机序列的生成 · 通过随机全排列生成随机序列 · 通过set集合去重生成随机序列 随机数的生 ...

  4. Python随机数、随机序列生成

    主要包括两部分,第一部分是对官方文档的简要总结,第二部分是一些实际应用中使用到的随机数he随机数组生成例子, 第三部分是Numpy随机数生成. 1. 伪随机数生成模块 Python有一个伪随机数生成模 ...

  5. java 8位随机数_JAVA中生成指定位数随机数的方法总结

    JAVA中生成指定位数随机数的方法很多,下面列举几种比较常用的方法. 方法一.通过Math类 1 public static String getRandom1(intlen) {2 int rs = ...

  6. .net中如何生成不重复的随机数

    2019独角兽企业重金招聘Python工程师标准>>> .net中生成不重复的随机数的方法 //获取count个不大于maxNumber的整数,所有整数不重复.当然,count必须小 ...

  7. C#生成不重复的随机数

    C#生成不重复的随机数 在做能自动生成试卷的考试系统时,常常需要随机生成一组不重复的题目,在.net Framework中提供了一个专门用来产生随机数 http://www.jbxue.com/tag ...

  8. php随机数字不重复,php生成N个不重复的随机数

    php生成N个不重复的随机数 生成N个不重复的随机数,如何在php中实现呢?本文分享的这例php代码,可以实现随机数的'生成,生成多个不重复的随机数,有兴趣的朋友参考下. php生成N个不重复的随机数 ...

  9. php mysql随机数不重复,js生成不重复的随机数

    这篇文章主要为大家详细介绍了js生成不重复的随机数,具有一定的参考价值,可以用来参考一下. 感兴趣的小伙伴,下面一起跟随512笔记的小编罗X来看看吧. JS代码如下: /** * * @param * ...

最新文章

  1. 深度学习11个实用技巧
  2. 【自动驾驶】5. ROS和DDS的区别总结
  3. mysql模糊查询后分页_jsp模糊查询后的数据进行分页,但点击下一页后就查询全部的了...
  4. sql 计算两个小数乘积_数学家是如何计算出π的?
  5. 普元部署包部署找不到构建_让我们在5分钟内构建和部署AutoML解决方案
  6. asp.net 得到上一页地址
  7. spring roo_使用Spring Roo进行快速云开发–第2部分:VMware Cloud Foundry
  8. 匿名管道 阻塞_进程间通信-管道
  9. 开放域对话中粗粒度响应选择的上下文细到粗蒸馏
  10. python中文相似度_python比较两个文本的相似性
  11. 几个实用PPT排版技巧,让幻灯片不在枯燥
  12. oracle中sqlplus,Oracle sqlplus命令的详细解析
  13. 关于博弈论中的一硬币正反问题的分析
  14. 晶闸管相控交流调压的详细计算
  15. 极值点偏移问题的处理策略及探究(作业帮的毕冶老师总结)
  16. 如何画一块标准的PCB板?SMT工艺PCB要求
  17. 什么是区块链----概念
  18. JAVAFX界面跳转和加载不同的界面
  19. Nature子刊:灵活的语音皮质编码可增强与任务相关的声学信息的神经处理
  20. 晶联讯JLX12864G-086-PC-3S LCD显示屏 C51驱动代码

热门文章

  1. 2019年春运贵州道路客运预计达6700万人次
  2. DataGrip使用: 表的数据迁移-数据导出sql和执行sql
  3. MySQL MGR集群搭建
  4. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU特性介绍(3)- 命名规则
  5. git commit 规范指南
  6. Oracle创建表空间、创建用户以及授权
  7. shell之case和function
  8. 【转载】我目瞪口呆地望着即时通讯
  9. 今天的出了校门的即时通讯
  10. 【转载】会议是浪费工作时间的最佳去处