背景
在一些app或者会员推广的活动中,我们(被推荐者)总会被要求输入推荐者的一个验证码,很显然,这个验证码是和这个推荐者绑定着的。
问题
如果验证码的长度固定的话,比如6位;再加上字符串的来源也固定,比如“0-9”+“A-Z”,那么这个验证码的个数必然是有限的,通过什么方式才能避免生成的验证码不会重复?
-----虽然貌似有14亿个数(我没算错吧?)
推广验证码是如何生成的
- username或者userid(或者其他任何每个用户唯一的属性)的hash,这样可以和用户一一对应,即绑定
- 随机生成,然后插入数据库与用户名绑定
如何避免重复
- hash方式只要username/userid是每个用户唯一的,hash就
几乎不可能
重复 - 随机生成的方式也很简单,生成之后查一下数据库,如果存在,重新生成,循环直到不重复
验证码一般都是在规定的时间段内才是有效的。
生成一个,扫描下数据库,存在的话,递归一下!
递归检查数据库是否重复在用户量达到一定程度时效率较低(重复可能性高)
考虑采用一个固定偏移值+userid来做(纯数字)