产生惟一随机码的方法分析

1. 本身写代码产生随机的数字和字母组合,每产生1个去数据库查询该随机码是否已存在,若是已存在,则从新产生,直到不重复为止。html

     优势:没发现有啥优势。     java

     缺点:产生速度慢,还要查询数据库,当数据量大的时候,可能重复的机率会比较高,要查询屡次数据库.python

 

2. guid,该方法应该是用的比较多的。     git

  优势:使用简单方便,不用本身编写额外的代码     数据库

  缺点:占用数据库空间相对较大,特别是根据guid查询速度比较慢(毕竟是字符串)。dom

 

3. 主键+随机码的方式,咱们产生的随机码保存到数据库确定会有个主键,用该主键+随机字符来组合。产生步骤:     函数

  1) 先从id生成器中获取id,好比是155.     post

  2)填充成固定位数(好比8位)的字符串(不够位数的左边填0,超过位数直接使用该数字),获得:00000155     ui

  3)在每一个数字后面随机插入1个字母或其它非数字符号,获得:0A0F0R0Y0H1K5L5Mspa

   这样就能够获得1个随机的惟一的邀请码了。    

  优势:使用也比较简单,不用查询数据库。最大的优势是查询的时候,能够根据邀请码直接获得主键id,     

     而后根据id去数据库查询(速度很快),再比较查询出来的邀请码和用户提交的邀请码是否一致。    

  缺点:须要使用id产生器,若是主键是数据库自增加的就不太好用(须要先插入数据库获取id,再更新邀请码)。

 

4. 有时候产品经理说,我要求邀请码都是数字的。why?no why? 我喜欢。*(&^(^%&^$&^$ 把方法3变通下就能够实现惟一的纯数字随机码了。    

  1) 获取id: 155    

  2) 转换成8进制:233    

  3) 转为字符串,并在后面加'9'字符:2339    

  4)在后面随机产生若干个随机数字字符:2003967524987 

   转为8进制后就不会出现9这个字符,而后在后面加个'9',这样就能肯定惟一性。最后在后面产生一些随机数字就能够。

      优缺点同方法3

 

 

 

一个栗子

 

题目是这样子的:

作为 Apple Store App 独立开发者,你要搞限时促销,为你的应用生成激活码(或者优惠券),使用 Python 如何生成 200 个激活码(或者优惠券)?


分析

其实要生成激活码(邀请码)也是很简单的事, 好比随机生成.或者使用GUID,UUID等,很是简单

可是咱们得考虑存入以及验证的问题.

参考产生惟一随机码的方法分析。这篇文章的思路:

主键+随机码的方式.

这种方法优势:使用也比较简单,不用直接去查询数据库,而最大的优势是查询的时候,能够根据邀请码直接获得主键id, 而后根据id去数据库查询(速度很快),再比较查询出来的邀请码和用户提交的邀请码是否一致。

  1. 生成:id(数据库primary key )->16进制 + "L(标识符)" +随机码
  2. 获取id:获取16进制的id再转回10进制

实现

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import random
import string

def activation_code(id,length=10):
    '''
    id + L + 随机码
    string模块中的3个函数:string.letters,string.printable,string.printable
    '''
    prefix = hex(int(id))[2:]+ 'L'
    length = length - len(prefix)
    chars=string.ascii_letters+string.digits
    return prefix + ''.join([random.choice(chars) for i in range(length)])

def get_id(code):
    ''' Hex to Dec '''
    return str(int(code.upper(), 16))

if __name__=="__main__":
    for i in range(10,500,35):
        code = activation_code(i)
        id_hex = code.split('L')[0]
        id  = get_id(id_hex)
        print code,id

运行结果:

aLp5EzM4D2 10
2dL8TuFB2o 45
50LklqcpNp 80
73La8yOuo1 115
96LavIm2bS 150
b9LZd4PV3D 185
dcL05As00w 220
ffLeD0sy3C 255
122Lgi6YGs 290
145Ljin1B5 325
168L1k7ypr 360
18bL1RYoIE 395
1aeLaMAKrT 430
1d1LHbYL7X 465
相关文章
相关标签/搜索