產生惟一隨機碼的方法分析

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
相關文章
相關標籤/搜索